Compare commits
	
		
			957 Commits
		
	
	
		
			OpenSSL_0_
			...
			FIPS_TEST_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					bb67f28a1e | ||
| 
						 | 
					08f7417a98 | ||
| 
						 | 
					84c881d0b5 | ||
| 
						 | 
					f25209267f | ||
| 
						 | 
					07cc19fcac | ||
| 
						 | 
					34aca2b6b6 | ||
| 
						 | 
					67dbe90856 | ||
| 
						 | 
					4a29c4e39f | ||
| 
						 | 
					0902926150 | ||
| 
						 | 
					15d95d5f92 | ||
| 
						 | 
					0116eae43e | ||
| 
						 | 
					d01f1d89e3 | ||
| 
						 | 
					722a5c5ade | ||
| 
						 | 
					2788e3983e | ||
| 
						 | 
					5ba3ebb593 | ||
| 
						 | 
					2b19ce86dc | ||
| 
						 | 
					140e5c3f3b | ||
| 
						 | 
					77bc62c3a7 | ||
| 
						 | 
					42f335ca0e | ||
| 
						 | 
					43b30bf2c8 | ||
| 
						 | 
					06e12403e0 | ||
| 
						 | 
					03b3a0d022 | ||
| 
						 | 
					f840728f43 | ||
| 
						 | 
					30fc34625c | ||
| 
						 | 
					18f3210a35 | ||
| 
						 | 
					82da9623bf | ||
| 
						 | 
					7c0341dbc4 | ||
| 
						 | 
					7450139b8b | ||
| 
						 | 
					e85e5ca5ec | ||
| 
						 | 
					67cdaca99d | ||
| 
						 | 
					b00f715c96 | ||
| 
						 | 
					098927c384 | ||
| 
						 | 
					0eb8e0058c | ||
| 
						 | 
					56c55b0655 | ||
| 
						 | 
					e17d60d5fb | ||
| 
						 | 
					e32b08abc3 | ||
| 
						 | 
					2776beb91a | ||
| 
						 | 
					dca20343e0 | ||
| 
						 | 
					e99f6700e1 | ||
| 
						 | 
					3da3c85a3f | ||
| 
						 | 
					d58d546e2d | ||
| 
						 | 
					780b97aba6 | ||
| 
						 | 
					e0ec2d772c | ||
| 
						 | 
					5fbf6769fc | ||
| 
						 | 
					7bf79446c8 | ||
| 
						 | 
					bdee60fc1a | ||
| 
						 | 
					0b62d2f4c9 | ||
| 
						 | 
					4375ca95a4 | ||
| 
						 | 
					acce7b5963 | ||
| 
						 | 
					c5098ee16f | ||
| 
						 | 
					6d0e43d555 | ||
| 
						 | 
					9f32d49de9 | ||
| 
						 | 
					db84c9075b | ||
| 
						 | 
					e96fad9d2d | ||
| 
						 | 
					0c7b06714e | ||
| 
						 | 
					d893001918 | ||
| 
						 | 
					b8bd781b7e | ||
| 
						 | 
					bb792a485a | ||
| 
						 | 
					452421d059 | ||
| 
						 | 
					ea8399724e | ||
| 
						 | 
					26655341fc | ||
| 
						 | 
					5858d32a59 | ||
| 
						 | 
					0dfe532ea9 | ||
| 
						 | 
					5c567ffd4c | ||
| 
						 | 
					3bc1781994 | ||
| 
						 | 
					485bcc9cab | ||
| 
						 | 
					bb1bbb3274 | ||
| 
						 | 
					4bd7bc97e8 | ||
| 
						 | 
					4d4339922c | ||
| 
						 | 
					c3d03b70af | ||
| 
						 | 
					e4c2c550b9 | ||
| 
						 | 
					570357b7a8 | ||
| 
						 | 
					7044d328a2 | ||
| 
						 | 
					35d7cc8166 | ||
| 
						 | 
					80790d89ec | ||
| 
						 | 
					7bad200b49 | ||
| 
						 | 
					6b6f64da2d | ||
| 
						 | 
					31def5ae59 | ||
| 
						 | 
					713407a5c7 | ||
| 
						 | 
					db73333585 | ||
| 
						 | 
					84c9b6edb1 | ||
| 
						 | 
					e609c04994 | ||
| 
						 | 
					53cfa36d37 | ||
| 
						 | 
					b10bd63df3 | ||
| 
						 | 
					44a287747f | ||
| 
						 | 
					20a413620c | ||
| 
						 | 
					e99b588f1b | ||
| 
						 | 
					48a3f2818e | ||
| 
						 | 
					fc0e014ca3 | ||
| 
						 | 
					8baaeba881 | ||
| 
						 | 
					150ebacd8a | ||
| 
						 | 
					bedcd5c0bb | ||
| 
						 | 
					fd86c390eb | ||
| 
						 | 
					63453c025f | ||
| 
						 | 
					ecb1445ce2 | ||
| 
						 | 
					64c32bf9eb | ||
| 
						 | 
					775e82c58d | ||
| 
						 | 
					db5cbd8954 | ||
| 
						 | 
					c6012b252d | ||
| 
						 | 
					e1ff593dcb | ||
| 
						 | 
					c4d9c13a31 | ||
| 
						 | 
					00c1c6cb28 | ||
| 
						 | 
					973fbfe3a3 | ||
| 
						 | 
					9fc1d3f4c4 | ||
| 
						 | 
					765863f0bf | ||
| 
						 | 
					cbd72088ec | ||
| 
						 | 
					8aabdf3505 | ||
| 
						 | 
					fcec494072 | ||
| 
						 | 
					88f62fb98a | ||
| 
						 | 
					69488fa929 | ||
| 
						 | 
					b0367dde56 | ||
| 
						 | 
					ad93095f16 | ||
| 
						 | 
					82b47955fc | ||
| 
						 | 
					95477d36f6 | ||
| 
						 | 
					eb798944b3 | ||
| 
						 | 
					b1ca6f2f3d | ||
| 
						 | 
					102e6481ae | ||
| 
						 | 
					97949ccfc8 | ||
| 
						 | 
					44e9bc81eb | ||
| 
						 | 
					4b27a9feb3 | ||
| 
						 | 
					0649b6f0f2 | ||
| 
						 | 
					389ff2e01f | ||
| 
						 | 
					8cf1846857 | ||
| 
						 | 
					2dab26339d | ||
| 
						 | 
					239e31f896 | ||
| 
						 | 
					4bf3222d96 | ||
| 
						 | 
					3380c4561e | ||
| 
						 | 
					3f2f0c8892 | ||
| 
						 | 
					0ee883650d | ||
| 
						 | 
					70cf309517 | ||
| 
						 | 
					8b5bf52ac2 | ||
| 
						 | 
					73a9485081 | ||
| 
						 | 
					d37a65bc81 | ||
| 
						 | 
					9dc4f157bc | ||
| 
						 | 
					34c7ff6dc9 | ||
| 
						 | 
					647907918d | ||
| 
						 | 
					cee73df3bd | ||
| 
						 | 
					07481951f9 | ||
| 
						 | 
					f15c448a72 | ||
| 
						 | 
					fcb41c0ee8 | ||
| 
						 | 
					8513320593 | ||
| 
						 | 
					9b62318311 | ||
| 
						 | 
					c1efb6705f | ||
| 
						 | 
					5f1841cdca | ||
| 
						 | 
					4b45051902 | ||
| 
						 | 
					f07320eae0 | ||
| 
						 | 
					9e5790ce21 | ||
| 
						 | 
					a0724cb261 | ||
| 
						 | 
					cdbba1067f | ||
| 
						 | 
					d837ca70f7 | ||
| 
						 | 
					fb64e17555 | ||
| 
						 | 
					e8f245d243 | ||
| 
						 | 
					fce8c6cc53 | ||
| 
						 | 
					0ff469d38d | ||
| 
						 | 
					73f3c281ff | ||
| 
						 | 
					05338b58ce | ||
| 
						 | 
					081057c3ff | ||
| 
						 | 
					94c1672ef0 | ||
| 
						 | 
					405d9761a5 | ||
| 
						 | 
					4c3a2d64e4 | ||
| 
						 | 
					6a62b2e54b | ||
| 
						 | 
					98a2fd32a0 | ||
| 
						 | 
					7bdeeb64ac | ||
| 
						 | 
					43b45a42fd | ||
| 
						 | 
					9af1bfb3d5 | ||
| 
						 | 
					aed14edd12 | ||
| 
						 | 
					14a948e6ad | ||
| 
						 | 
					af2fcf3a65 | ||
| 
						 | 
					4a676ac4f8 | ||
| 
						 | 
					37e27219f2 | ||
| 
						 | 
					d2284ab5d1 | ||
| 
						 | 
					78e91e7574 | ||
| 
						 | 
					c1668fe59d | ||
| 
						 | 
					e1cc0671ac | ||
| 
						 | 
					c1a8a5de13 | ||
| 
						 | 
					e3d0e0a792 | ||
| 
						 | 
					7c7667b86b | ||
| 
						 | 
					38be5db93b | ||
| 
						 | 
					6a50d0a422 | ||
| 
						 | 
					7ab2d30349 | ||
| 
						 | 
					d753c3f582 | ||
| 
						 | 
					1897c89302 | ||
| 
						 | 
					9aa260ab57 | ||
| 
						 | 
					c7e7d382d5 | ||
| 
						 | 
					3cc54008eb | ||
| 
						 | 
					ff8bcccdd4 | ||
| 
						 | 
					81170986ed | ||
| 
						 | 
					a93b01be57 | ||
| 
						 | 
					04b304d346 | ||
| 
						 | 
					6c61726b2a | ||
| 
						 | 
					cd202fe2f9 | ||
| 
						 | 
					69af4faec1 | ||
| 
						 | 
					4b21c202ff | ||
| 
						 | 
					df9e0bf507 | ||
| 
						 | 
					879b19801a | ||
| 
						 | 
					6ec8e63af6 | ||
| 
						 | 
					465b9f6b26 | ||
| 
						 | 
					0c9c87a76e | ||
| 
						 | 
					a7a90b2f00 | ||
| 
						 | 
					4d6e7733fa | ||
| 
						 | 
					2deadf1672 | ||
| 
						 | 
					9ea862e0b3 | ||
| 
						 | 
					11c9b7cfeb | ||
| 
						 | 
					b08868c48a | ||
| 
						 | 
					9ca46ff609 | ||
| 
						 | 
					800e400de5 | ||
| 
						 | 
					05886a6f77 | ||
| 
						 | 
					667aef4c6a | ||
| 
						 | 
					49e179cc52 | ||
| 
						 | 
					aa4ce7315f | ||
| 
						 | 
					c741b83762 | ||
| 
						 | 
					64387788a9 | ||
| 
						 | 
					480506bd49 | ||
| 
						 | 
					0d5ea7613e | ||
| 
						 | 
					beb056b303 | ||
| 
						 | 
					4e321ffaff | ||
| 
						 | 
					6ededa42db | ||
| 
						 | 
					36d16f8ee0 | ||
| 
						 | 
					ab781a0cb6 | ||
| 
						 | 
					19c2987eb6 | ||
| 
						 | 
					b09af97686 | ||
| 
						 | 
					a7b1c7732f | ||
| 
						 | 
					abc64463af | ||
| 
						 | 
					2e7245f5a3 | ||
| 
						 | 
					f76b062e16 | ||
| 
						 | 
					cc1717eaa4 | ||
| 
						 | 
					c5156d952e | ||
| 
						 | 
					0b2d0d7d13 | ||
| 
						 | 
					b732a8cf5f | ||
| 
						 | 
					a7dc451ebe | ||
| 
						 | 
					1e764f463e | ||
| 
						 | 
					87357fc0b8 | ||
| 
						 | 
					a2c96d888d | ||
| 
						 | 
					a7a0af0ca4 | ||
| 
						 | 
					9a6c6b99bf | ||
| 
						 | 
					033c79dff1 | ||
| 
						 | 
					b362536275 | ||
| 
						 | 
					aa16a28631 | ||
| 
						 | 
					2757c67da2 | ||
| 
						 | 
					148111ff0a | ||
| 
						 | 
					3d5fd31280 | ||
| 
						 | 
					c7199e62f1 | ||
| 
						 | 
					0b3fc6e63b | ||
| 
						 | 
					c2db9cfb52 | ||
| 
						 | 
					6bc8e6b898 | ||
| 
						 | 
					6eb4958989 | ||
| 
						 | 
					9edf4e8157 | ||
| 
						 | 
					b07a7b5daa | ||
| 
						 | 
					965a1cb92e | ||
| 
						 | 
					e9ad6665a5 | ||
| 
						 | 
					b5855b2f32 | ||
| 
						 | 
					a0bee97e55 | ||
| 
						 | 
					e7076c5a80 | ||
| 
						 | 
					ff22e913a3 | ||
| 
						 | 
					132f25950b | ||
| 
						 | 
					4ed56cba63 | ||
| 
						 | 
					145878ca29 | ||
| 
						 | 
					a36c30136e | ||
| 
						 | 
					04d0d0accf | ||
| 
						 | 
					92ad8e5c37 | ||
| 
						 | 
					00df894701 | ||
| 
						 | 
					630e4a6e59 | ||
| 
						 | 
					bf2336f478 | ||
| 
						 | 
					4f6c2bacb1 | ||
| 
						 | 
					384dba6edb | ||
| 
						 | 
					2c45bf2bc9 | ||
| 
						 | 
					836ec0c764 | ||
| 
						 | 
					5e72fb063a | ||
| 
						 | 
					d9536ccffa | ||
| 
						 | 
					37ce8cffcc | ||
| 
						 | 
					2dc08d5f5d | ||
| 
						 | 
					00b8abee61 | ||
| 
						 | 
					7efebab9fd | ||
| 
						 | 
					a74286d636 | ||
| 
						 | 
					254cfe878e | ||
| 
						 | 
					ed824195a1 | ||
| 
						 | 
					22c3600e4c | ||
| 
						 | 
					49f386578e | ||
| 
						 | 
					7c671508bd | ||
| 
						 | 
					76693ca0a3 | ||
| 
						 | 
					d3fdc27aa8 | ||
| 
						 | 
					4182f0ffc7 | ||
| 
						 | 
					40e950aed6 | ||
| 
						 | 
					0ef4ec4fd4 | ||
| 
						 | 
					f868b61376 | ||
| 
						 | 
					987bebaf8c | ||
| 
						 | 
					65f0efe198 | ||
| 
						 | 
					e77d8f2ecd | ||
| 
						 | 
					f68854b4c3 | ||
| 
						 | 
					c61a8ad5b0 | ||
| 
						 | 
					89234b1eed | ||
| 
						 | 
					2ec5ebb979 | ||
| 
						 | 
					863a155451 | ||
| 
						 | 
					1ddce0bebf | ||
| 
						 | 
					4347c0a76d | ||
| 
						 | 
					f1429a972f | ||
| 
						 | 
					45bc841b22 | ||
| 
						 | 
					7a111bc864 | ||
| 
						 | 
					1cfd258ed6 | ||
| 
						 | 
					04d7d51ea2 | ||
| 
						 | 
					48d0ba4a1e | ||
| 
						 | 
					0e23faec0a | ||
| 
						 | 
					7590f37fd7 | ||
| 
						 | 
					2906dc8601 | ||
| 
						 | 
					c8d5c71af5 | ||
| 
						 | 
					ff990440ee | ||
| 
						 | 
					0e304b7f41 | ||
| 
						 | 
					f97b4a776e | ||
| 
						 | 
					b99daf76a7 | ||
| 
						 | 
					8fc6cb77c5 | ||
| 
						 | 
					fbe6ba81e9 | ||
| 
						 | 
					b219bb8f62 | ||
| 
						 | 
					2b85e23d2e | ||
| 
						 | 
					026bb0b96a | ||
| 
						 | 
					6424498226 | ||
| 
						 | 
					0b418c7d51 | ||
| 
						 | 
					13051e9316 | ||
| 
						 | 
					0174c56851 | ||
| 
						 | 
					3ed449e94a | ||
| 
						 | 
					4f1c33b430 | ||
| 
						 | 
					1334462ab3 | ||
| 
						 | 
					a34f2d42b4 | ||
| 
						 | 
					5dc4923359 | ||
| 
						 | 
					e62991a07c | ||
| 
						 | 
					52272327f3 | ||
| 
						 | 
					5820d87a5f | ||
| 
						 | 
					1bf955920a | ||
| 
						 | 
					89b1fd98ac | ||
| 
						 | 
					51d28013db | ||
| 
						 | 
					ee2bf876c2 | ||
| 
						 | 
					8861ba355d | ||
| 
						 | 
					e44f62c2b1 | ||
| 
						 | 
					9e88c82703 | ||
| 
						 | 
					9d2f51c086 | ||
| 
						 | 
					ad0db060b1 | ||
| 
						 | 
					3547478fc8 | ||
| 
						 | 
					29dc350813 | ||
| 
						 | 
					342b7e0458 | ||
| 
						 | 
					bc3cae7e7d | ||
| 
						 | 
					96534114a3 | ||
| 
						 | 
					4ecd7d2b7e | ||
| 
						 | 
					9d728b8d10 | ||
| 
						 | 
					37942fab51 | ||
| 
						 | 
					d060fc9ff2 | ||
| 
						 | 
					22e5a7935f | ||
| 
						 | 
					01671ab2df | ||
| 
						 | 
					36521f0150 | ||
| 
						 | 
					93aeac64ce | ||
| 
						 | 
					9addd9b6fb | ||
| 
						 | 
					0231911dec | ||
| 
						 | 
					4bb61becbb | ||
| 
						 | 
					b392e52050 | ||
| 
						 | 
					0858b71b41 | ||
| 
						 | 
					657129f748 | ||
| 
						 | 
					c710c7b3a3 | ||
| 
						 | 
					ff731ae3db | ||
| 
						 | 
					d9bfe4f97c | ||
| 
						 | 
					dc0ed30cfe | ||
| 
						 | 
					e248596bac | ||
| 
						 | 
					6049399baf | ||
| 
						 | 
					f763e0b5ae | ||
| 
						 | 
					eb3eab20a8 | ||
| 
						 | 
					6d69d74bb8 | ||
| 
						 | 
					4848cbf1cf | ||
| 
						 | 
					9f2027e56d | ||
| 
						 | 
					4d2b407ba2 | ||
| 
						 | 
					e1d51de41f | ||
| 
						 | 
					81ee80ab88 | ||
| 
						 | 
					7d727231b7 | ||
| 
						 | 
					69740c2b3f | ||
| 
						 | 
					119d1a1dd4 | ||
| 
						 | 
					afe01cd3f6 | ||
| 
						 | 
					70f34a5841 | ||
| 
						 | 
					c2e40d0f9a | ||
| 
						 | 
					0abfd60604 | ||
| 
						 | 
					e5dbccc182 | ||
| 
						 | 
					f8fa22d826 | ||
| 
						 | 
					c393222280 | ||
| 
						 | 
					631bae4723 | ||
| 
						 | 
					f6bfb559f7 | ||
| 
						 | 
					60fd574cdf | ||
| 
						 | 
					73705abc34 | ||
| 
						 | 
					12bdb64375 | ||
| 
						 | 
					7bdf8eed69 | ||
| 
						 | 
					bbc0ac37b0 | ||
| 
						 | 
					48c832b6b7 | ||
| 
						 | 
					8298632d14 | ||
| 
						 | 
					f3e427f6f9 | ||
| 
						 | 
					62a25c6129 | ||
| 
						 | 
					8bb826ee53 | ||
| 
						 | 
					ce53d920fb | ||
| 
						 | 
					884b3fc23c | ||
| 
						 | 
					5d1430f390 | ||
| 
						 | 
					45d10efc35 | ||
| 
						 | 
					db3cb0e97a | ||
| 
						 | 
					41a15c4f0f | ||
| 
						 | 
					fea4280a8b | ||
| 
						 | 
					e852b8533f | ||
| 
						 | 
					20a3439ea9 | ||
| 
						 | 
					a273a2824c | ||
| 
						 | 
					24c97c819d | ||
| 
						 | 
					42ba5d2329 | ||
| 
						 | 
					c3e6402857 | ||
| 
						 | 
					0821bcd4de | ||
| 
						 | 
					c3e28480d7 | ||
| 
						 | 
					4a6a2032ed | ||
| 
						 | 
					e72b9658f8 | ||
| 
						 | 
					c01d2b974e | ||
| 
						 | 
					8c04994bfe | ||
| 
						 | 
					989c0f8215 | ||
| 
						 | 
					b0ef321cc8 | ||
| 
						 | 
					7a8c728860 | ||
| 
						 | 
					4cf8f9369c | ||
| 
						 | 
					6141b86a49 | ||
| 
						 | 
					2950db5995 | ||
| 
						 | 
					801fea5f11 | ||
| 
						 | 
					da26bcb5de | ||
| 
						 | 
					23fadaa084 | ||
| 
						 | 
					d99382039c | ||
| 
						 | 
					9c29e781a8 | ||
| 
						 | 
					93acf33440 | ||
| 
						 | 
					5c1fd5e316 | ||
| 
						 | 
					f42a82777d | ||
| 
						 | 
					0c7ceb3748 | ||
| 
						 | 
					e27a259696 | ||
| 
						 | 
					41e455bfc4 | ||
| 
						 | 
					e54e4bcf1f | ||
| 
						 | 
					fe8b77753c | ||
| 
						 | 
					d5c2bc4bff | ||
| 
						 | 
					59b6836ab2 | ||
| 
						 | 
					61823b6a74 | ||
| 
						 | 
					9fc9b55237 | ||
| 
						 | 
					ab0def8152 | ||
| 
						 | 
					689c6f2542 | ||
| 
						 | 
					f4bfd357e5 | ||
| 
						 | 
					6d2a7098d6 | ||
| 
						 | 
					130db968b8 | ||
| 
						 | 
					8d274837e5 | ||
| 
						 | 
					5855038049 | ||
| 
						 | 
					b43b9de9e4 | ||
| 
						 | 
					d18685d959 | ||
| 
						 | 
					9f6715d4bb | ||
| 
						 | 
					ab185b6038 | ||
| 
						 | 
					6286bbecef | ||
| 
						 | 
					1642000707 | ||
| 
						 | 
					9d14506f29 | ||
| 
						 | 
					7ec40a480b | ||
| 
						 | 
					aa0d4ed5fa | ||
| 
						 | 
					2cf68c0b1a | ||
| 
						 | 
					f7f2125522 | ||
| 
						 | 
					2b61034b0b | ||
| 
						 | 
					97d49cdd6f | ||
| 
						 | 
					80c808b90b | ||
| 
						 | 
					af1048c25c | ||
| 
						 | 
					ecc5ef8793 | ||
| 
						 | 
					c9a112f540 | ||
| 
						 | 
					5286db697f | ||
| 
						 | 
					126179aad0 | ||
| 
						 | 
					f69a8aebab | ||
| 
						 | 
					e22e6bf0be | ||
| 
						 | 
					2ecf923286 | ||
| 
						 | 
					9d10b15ef9 | ||
| 
						 | 
					da30c74a27 | ||
| 
						 | 
					67ea999d4a | ||
| 
						 | 
					e1892f2370 | ||
| 
						 | 
					fe28866d71 | ||
| 
						 | 
					b7fd453675 | ||
| 
						 | 
					de4ab1e629 | ||
| 
						 | 
					216ddfaf6b | ||
| 
						 | 
					086dd3032f | ||
| 
						 | 
					20e5177105 | ||
| 
						 | 
					8aa36bcac9 | ||
| 
						 | 
					bb987c73a9 | ||
| 
						 | 
					485e30dbe1 | ||
| 
						 | 
					515ac3debb | ||
| 
						 | 
					877dbcb8a0 | ||
| 
						 | 
					43509de33d | ||
| 
						 | 
					62d27939c2 | ||
| 
						 | 
					dbaa6f91aa | ||
| 
						 | 
					01b62dca25 | ||
| 
						 | 
					66d68327cb | ||
| 
						 | 
					ecc3d2734d | ||
| 
						 | 
					11536fbac8 | ||
| 
						 | 
					7cfcca8ba3 | ||
| 
						 | 
					8c3c570134 | ||
| 
						 | 
					0cae19f5ef | ||
| 
						 | 
					97a1630e81 | ||
| 
						 | 
					6be00c7e16 | ||
| 
						 | 
					bf746f0f46 | ||
| 
						 | 
					532d936be8 | ||
| 
						 | 
					a229e3038e | ||
| 
						 | 
					d88edf1447 | ||
| 
						 | 
					4aca9297dc | ||
| 
						 | 
					f60fc19a69 | ||
| 
						 | 
					d0edffc7da | ||
| 
						 | 
					b2c5960935 | ||
| 
						 | 
					12dfa84310 | ||
| 
						 | 
					fbdce13e5a | ||
| 
						 | 
					e532a6c449 | ||
| 
						 | 
					14bcdb087f | ||
| 
						 | 
					b7efa56a4a | ||
| 
						 | 
					8359421d90 | ||
| 
						 | 
					efde5230f1 | ||
| 
						 | 
					f5ffad9d1d | ||
| 
						 | 
					57a68b2129 | ||
| 
						 | 
					bac252a5e3 | ||
| 
						 | 
					a963395a7b | ||
| 
						 | 
					d8863f0bdb | ||
| 
						 | 
					addb6e16a8 | ||
| 
						 | 
					4d27c4c960 | ||
| 
						 | 
					ed65fab910 | ||
| 
						 | 
					90cc40911b | ||
| 
						 | 
					134d6a44ec | ||
| 
						 | 
					a7201e9a1b | ||
| 
						 | 
					420eb6a306 | ||
| 
						 | 
					fcd5cca418 | ||
| 
						 | 
					9222bc6b4e | ||
| 
						 | 
					e9ddd85965 | ||
| 
						 | 
					ea28f93c2d | ||
| 
						 | 
					adeb20b6b7 | ||
| 
						 | 
					086b64d0d3 | ||
| 
						 | 
					e6d27baf52 | ||
| 
						 | 
					e7e1150706 | ||
| 
						 | 
					5d727078ac | ||
| 
						 | 
					108159ffcc | ||
| 
						 | 
					c4d423511a | ||
| 
						 | 
					b15a93a9c5 | ||
| 
						 | 
					47c88d7413 | ||
| 
						 | 
					630b9d70fb | ||
| 
						 | 
					c4929fb841 | ||
| 
						 | 
					97c2c819b3 | ||
| 
						 | 
					954f3c3126 | ||
| 
						 | 
					d9248e5780 | ||
| 
						 | 
					0b52f89b81 | ||
| 
						 | 
					528584c595 | ||
| 
						 | 
					5cdf5e3308 | ||
| 
						 | 
					7de4b5b060 | ||
| 
						 | 
					02a00bb054 | ||
| 
						 | 
					b58560b915 | ||
| 
						 | 
					76d088046c | ||
| 
						 | 
					83f69163fd | ||
| 
						 | 
					3b4de6e4cc | ||
| 
						 | 
					bdbc9b4d1a | ||
| 
						 | 
					5ca3a0aa86 | ||
| 
						 | 
					702be727c0 | ||
| 
						 | 
					09ef94d2c9 | ||
| 
						 | 
					8336cec34d | ||
| 
						 | 
					3ffb8d42bc | ||
| 
						 | 
					1c8415fdf3 | ||
| 
						 | 
					25866e3982 | ||
| 
						 | 
					3b3df98ca6 | ||
| 
						 | 
					2e4a99f38b | ||
| 
						 | 
					e90faddaf8 | ||
| 
						 | 
					370d418a7b | ||
| 
						 | 
					f1ce306f30 | ||
| 
						 | 
					37b11ca78e | ||
| 
						 | 
					a17af9e277 | ||
| 
						 | 
					6951c23afd | ||
| 
						 | 
					4aaa4f267d | ||
| 
						 | 
					de421076a5 | ||
| 
						 | 
					f709ffe832 | ||
| 
						 | 
					bd16cd6bcc | ||
| 
						 | 
					0c51600203 | ||
| 
						 | 
					9e34e806a2 | ||
| 
						 | 
					2d16a957e0 | ||
| 
						 | 
					9850f7f6b2 | ||
| 
						 | 
					131e064e4a | ||
| 
						 | 
					556b8f3f77 | ||
| 
						 | 
					045d3285e2 | ||
| 
						 | 
					d1df5b4339 | ||
| 
						 | 
					25558bf743 | ||
| 
						 | 
					713147109c | ||
| 
						 | 
					76ef6ac956 | ||
| 
						 | 
					fe707c3260 | ||
| 
						 | 
					fb39cd850c | ||
| 
						 | 
					560f01fff9 | ||
| 
						 | 
					15bbc1574f | ||
| 
						 | 
					1acf071cd0 | ||
| 
						 | 
					3ae613e34f | ||
| 
						 | 
					a842df6659 | ||
| 
						 | 
					c05a7f5dfd | ||
| 
						 | 
					627bd6709c | ||
| 
						 | 
					fbf218b8c3 | ||
| 
						 | 
					3c97bd833b | ||
| 
						 | 
					37ece6156a | ||
| 
						 | 
					abbc186bd2 | ||
| 
						 | 
					de6859e442 | ||
| 
						 | 
					965574039b | ||
| 
						 | 
					5e8904f289 | ||
| 
						 | 
					535178f415 | ||
| 
						 | 
					a4a88eea03 | ||
| 
						 | 
					a661c1728f | ||
| 
						 | 
					13e387c3fe | ||
| 
						 | 
					0c0788ba0a | ||
| 
						 | 
					3dd16fb7fd | ||
| 
						 | 
					ab09133881 | ||
| 
						 | 
					90ec459be0 | ||
| 
						 | 
					3d5d6f9658 | ||
| 
						 | 
					bd5a2195de | ||
| 
						 | 
					5868130e7a | ||
| 
						 | 
					905fd45b36 | ||
| 
						 | 
					c162b132eb | ||
| 
						 | 
					a4c9668f3c | ||
| 
						 | 
					f1ca15dd69 | ||
| 
						 | 
					b4e0ce5165 | ||
| 
						 | 
					17f0e916db | ||
| 
						 | 
					3d4c78e7f5 | ||
| 
						 | 
					95f5b1fdae | ||
| 
						 | 
					c78b389cb3 | ||
| 
						 | 
					3dfa23cbc4 | ||
| 
						 | 
					b0ab906524 | ||
| 
						 | 
					a37e22d866 | ||
| 
						 | 
					41c70d47d7 | ||
| 
						 | 
					ec46cd8bb8 | ||
| 
						 | 
					da8534693c | ||
| 
						 | 
					a0e7c8eede | ||
| 
						 | 
					b56b02dc75 | ||
| 
						 | 
					a8e00b17ce | ||
| 
						 | 
					c98175bf88 | ||
| 
						 | 
					3e66ee9f01 | ||
| 
						 | 
					3384bdd6fe | ||
| 
						 | 
					5b40d7dd97 | ||
| 
						 | 
					8db8893cd7 | ||
| 
						 | 
					8f284faaec | ||
| 
						 | 
					3010b1730e | ||
| 
						 | 
					f670069a19 | ||
| 
						 | 
					575dbdc965 | ||
| 
						 | 
					f774accdbf | ||
| 
						 | 
					8544a80776 | ||
| 
						 | 
					2e1366366e | ||
| 
						 | 
					fda344ece8 | ||
| 
						 | 
					280e3bd2c9 | ||
| 
						 | 
					7c69478064 | ||
| 
						 | 
					41191d14ce | ||
| 
						 | 
					1862dae862 | ||
| 
						 | 
					62c19d2dd9 | ||
| 
						 | 
					2d1a37bc9f | ||
| 
						 | 
					24e85c3dee | ||
| 
						 | 
					b7b46c9a87 | ||
| 
						 | 
					e6e1f4cb5e | ||
| 
						 | 
					5073ff0346 | ||
| 
						 | 
					fa032a6941 | ||
| 
						 | 
					fc7fc5678f | ||
| 
						 | 
					7a3240e319 | ||
| 
						 | 
					5022e4ecdf | ||
| 
						 | 
					d133618ce2 | ||
| 
						 | 
					30b415b076 | ||
| 
						 | 
					cd52956357 | ||
| 
						 | 
					914c2a28c0 | ||
| 
						 | 
					6826d26ea7 | ||
| 
						 | 
					18ad97bbe7 | ||
| 
						 | 
					ea681ba872 | ||
| 
						 | 
					bc3e7fabe7 | ||
| 
						 | 
					d675c74d14 | ||
| 
						 | 
					ee3f520276 | ||
| 
						 | 
					59c7029862 | ||
| 
						 | 
					9199bd0cd7 | ||
| 
						 | 
					4443f44012 | ||
| 
						 | 
					1582a4073e | ||
| 
						 | 
					401ee37a3e | ||
| 
						 | 
					cb26a20cb1 | ||
| 
						 | 
					82c4674e47 | ||
| 
						 | 
					dfcf822c65 | ||
| 
						 | 
					9d2996b82f | ||
| 
						 | 
					14c8986f75 | ||
| 
						 | 
					3fee255102 | ||
| 
						 | 
					6237528c82 | ||
| 
						 | 
					16df5f066a | ||
| 
						 | 
					959f9b1158 | ||
| 
						 | 
					376729e130 | ||
| 
						 | 
					2b354390b8 | ||
| 
						 | 
					00dd8f6d6e | ||
| 
						 | 
					5dd87981bf | ||
| 
						 | 
					37dccd8ff2 | ||
| 
						 | 
					826a42a088 | ||
| 
						 | 
					19f39703f7 | ||
| 
						 | 
					1ec0d15e54 | ||
| 
						 | 
					151368ccba | ||
| 
						 | 
					4451c2558e | ||
| 
						 | 
					ce165addd2 | ||
| 
						 | 
					b207a73ca6 | ||
| 
						 | 
					4a64f3d665 | ||
| 
						 | 
					5fee606442 | ||
| 
						 | 
					22a7a3b91b | ||
| 
						 | 
					ced27cc681 | ||
| 
						 | 
					ffec31f1ac | ||
| 
						 | 
					521aaafc6a | ||
| 
						 | 
					e510c62a38 | ||
| 
						 | 
					78df5a2f1e | ||
| 
						 | 
					671c1bcfce | ||
| 
						 | 
					6c9f57d629 | ||
| 
						 | 
					382342ce1d | ||
| 
						 | 
					28a896f7fe | ||
| 
						 | 
					69c922f5d2 | ||
| 
						 | 
					f6549efa61 | ||
| 
						 | 
					10c8505734 | ||
| 
						 | 
					4ae135eb0d | ||
| 
						 | 
					10f92aac33 | ||
| 
						 | 
					9262f5a3fa | ||
| 
						 | 
					f94481196c | ||
| 
						 | 
					68d9e764cb | ||
| 
						 | 
					17f847af21 | ||
| 
						 | 
					8de69cf2c6 | ||
| 
						 | 
					a2ac429da2 | ||
| 
						 | 
					a2617f727d | ||
| 
						 | 
					ffd0f93f14 | ||
| 
						 | 
					15aa44d230 | ||
| 
						 | 
					3955a76946 | ||
| 
						 | 
					ee478901b0 | ||
| 
						 | 
					1a4b8e7cee | ||
| 
						 | 
					a28e18219b | ||
| 
						 | 
					871080b94b | ||
| 
						 | 
					c133cb8974 | ||
| 
						 | 
					03386677ed | ||
| 
						 | 
					559f90ff60 | ||
| 
						 | 
					2f547d2c1c | ||
| 
						 | 
					c284f20f00 | ||
| 
						 | 
					58ae65cd1a | ||
| 
						 | 
					5b0f1f7d13 | ||
| 
						 | 
					785e827323 | ||
| 
						 | 
					2f605e8d24 | ||
| 
						 | 
					5e2216bfa1 | ||
| 
						 | 
					175ac6811a | ||
| 
						 | 
					07d488daf6 | ||
| 
						 | 
					d1360f6ecc | ||
| 
						 | 
					c38ff58b6b | ||
| 
						 | 
					c29ef588dc | ||
| 
						 | 
					968c31bd84 | ||
| 
						 | 
					c743966156 | ||
| 
						 | 
					bb09fd2bb6 | ||
| 
						 | 
					280eb33b59 | ||
| 
						 | 
					f79110c633 | ||
| 
						 | 
					6ef2ff62fc | ||
| 
						 | 
					980aea7860 | ||
| 
						 | 
					bd9327baa9 | ||
| 
						 | 
					6f9bafafa3 | ||
| 
						 | 
					422a4a33a5 | ||
| 
						 | 
					58606421ae | ||
| 
						 | 
					d813ff2ac1 | ||
| 
						 | 
					36734b2bab | ||
| 
						 | 
					c85c5c408a | ||
| 
						 | 
					2c1677d703 | ||
| 
						 | 
					72348cbb8d | ||
| 
						 | 
					c431798e82 | ||
| 
						 | 
					fb80794568 | ||
| 
						 | 
					4ec3d785e5 | ||
| 
						 | 
					5d7c222db8 | ||
| 
						 | 
					d993addbed | ||
| 
						 | 
					476b6ab541 | ||
| 
						 | 
					16760a3089 | ||
| 
						 | 
					2b247cf81f | ||
| 
						 | 
					746fc2526f | ||
| 
						 | 
					a8c65b400c | ||
| 
						 | 
					526975906b | ||
| 
						 | 
					14fa6ad9f9 | ||
| 
						 | 
					e544b0dc2a | ||
| 
						 | 
					2549564009 | ||
| 
						 | 
					bb1a915c24 | ||
| 
						 | 
					b94f886b22 | ||
| 
						 | 
					6ef7b78e7c | ||
| 
						 | 
					e08aad1d14 | ||
| 
						 | 
					b5a93e2250 | ||
| 
						 | 
					c128bb0fa2 | ||
| 
						 | 
					30fe028f07 | ||
| 
						 | 
					b88606c28e | ||
| 
						 | 
					2ea6abf6e5 | ||
| 
						 | 
					f8c469de73 | ||
| 
						 | 
					42096e05f7 | ||
| 
						 | 
					7d15a556f8 | ||
| 
						 | 
					5b17246324 | ||
| 
						 | 
					c77094415f | ||
| 
						 | 
					34413fca84 | ||
| 
						 | 
					ec38ddc765 | ||
| 
						 | 
					8aae01e223 | ||
| 
						 | 
					00555c2f2f | ||
| 
						 | 
					07d80f6f35 | ||
| 
						 | 
					4591850561 | ||
| 
						 | 
					a25aca2943 | ||
| 
						 | 
					48c524827b | ||
| 
						 | 
					ebaec63e3e | ||
| 
						 | 
					14e21f863a | ||
| 
						 | 
					f10725a6e1 | ||
| 
						 | 
					0f71b77d5c | ||
| 
						 | 
					d6bb6a88be | ||
| 
						 | 
					3205db2bfe | ||
| 
						 | 
					6f86850eec | ||
| 
						 | 
					16ab8a93bc | ||
| 
						 | 
					c88f8f76b5 | ||
| 
						 | 
					fbf96849e9 | ||
| 
						 | 
					d70e2507f8 | ||
| 
						 | 
					2fcf435d73 | ||
| 
						 | 
					da2ee71de5 | ||
| 
						 | 
					8611934352 | ||
| 
						 | 
					01e94efd46 | ||
| 
						 | 
					33c3ecf741 | ||
| 
						 | 
					5bd4c26057 | ||
| 
						 | 
					4aa5889e1a | ||
| 
						 | 
					bafcc7e060 | ||
| 
						 | 
					afe67fb28e | ||
| 
						 | 
					f744f92adb | ||
| 
						 | 
					75f134c077 | ||
| 
						 | 
					d8d25c9603 | ||
| 
						 | 
					f1bdf1d518 | ||
| 
						 | 
					d58caee734 | ||
| 
						 | 
					e39c2548f5 | ||
| 
						 | 
					8169dd73f9 | ||
| 
						 | 
					765e231a7c | ||
| 
						 | 
					89c53672c2 | ||
| 
						 | 
					64ba6cf222 | ||
| 
						 | 
					210a4f78ae | ||
| 
						 | 
					334ef04949 | ||
| 
						 | 
					859ceeeb51 | ||
| 
						 | 
					22edcae7fa | ||
| 
						 | 
					d0590fe6b2 | ||
| 
						 | 
					2232b10f5a | ||
| 
						 | 
					e34794dd1b | ||
| 
						 | 
					0210065bbd | ||
| 
						 | 
					7f5b4dd1e8 | ||
| 
						 | 
					5906e8d5fe | ||
| 
						 | 
					5545607c4f | ||
| 
						 | 
					6ac1571296 | ||
| 
						 | 
					ca74b76f3e | ||
| 
						 | 
					2b6174c478 | ||
| 
						 | 
					2b002273f3 | ||
| 
						 | 
					15d155e45a | ||
| 
						 | 
					b0841348b6 | ||
| 
						 | 
					090e81d4aa | ||
| 
						 | 
					e4528e48e3 | ||
| 
						 | 
					235dee1421 | ||
| 
						 | 
					d28f7bc74d | ||
| 
						 | 
					4083a229b4 | ||
| 
						 | 
					a2400fcab8 | ||
| 
						 | 
					dc56eb5079 | ||
| 
						 | 
					637ff35ef6 | ||
| 
						 | 
					ace3ebd661 | ||
| 
						 | 
					eea674567c | ||
| 
						 | 
					c39c32dd65 | ||
| 
						 | 
					0efea28dcb | ||
| 
						 | 
					4bab9b763d | ||
| 
						 | 
					70696f4525 | ||
| 
						 | 
					80bbc9ceaf | ||
| 
						 | 
					51ce5230cd | ||
| 
						 | 
					b6d8ba11e9 | ||
| 
						 | 
					e2f2a9af2c | ||
| 
						 | 
					28a8003467 | ||
| 
						 | 
					563cd0f2b0 | ||
| 
						 | 
					3ac0f28837 | ||
| 
						 | 
					47c1735acd | ||
| 
						 | 
					7d3932e8cf | ||
| 
						 | 
					8a60547896 | ||
| 
						 | 
					d459e39012 | ||
| 
						 | 
					340f5856ec | ||
| 
						 | 
					df11e1e921 | ||
| 
						 | 
					6a6592962c | ||
| 
						 | 
					1275c4569e | ||
| 
						 | 
					afbe74d386 | ||
| 
						 | 
					f18ea6cae9 | ||
| 
						 | 
					c9ff40cecd | ||
| 
						 | 
					9088d5f24f | ||
| 
						 | 
					cf9056cfda | ||
| 
						 | 
					f7fc4ca1dd | ||
| 
						 | 
					132fc53223 | ||
| 
						 | 
					b3b6720944 | ||
| 
						 | 
					9f6ea7163b | ||
| 
						 | 
					385c8e89f4 | ||
| 
						 | 
					263e3151e2 | ||
| 
						 | 
					9081980565 | ||
| 
						 | 
					393b704d28 | ||
| 
						 | 
					bef26f1158 | ||
| 
						 | 
					bc1ca8605c | ||
| 
						 | 
					ad5003409d | ||
| 
						 | 
					057cfaf2f8 | ||
| 
						 | 
					914d36ba19 | ||
| 
						 | 
					31c2ac1cdc | ||
| 
						 | 
					6bca8e3886 | ||
| 
						 | 
					63ba7e293f | ||
| 
						 | 
					31e9b9b2e9 | ||
| 
						 | 
					7997b13aa3 | ||
| 
						 | 
					a2eb9688a4 | ||
| 
						 | 
					af2bf07404 | ||
| 
						 | 
					8c5dfa4c99 | ||
| 
						 | 
					8d9fb0f04a | ||
| 
						 | 
					15fd2de37c | ||
| 
						 | 
					1a83c37294 | ||
| 
						 | 
					674ee8b72d | ||
| 
						 | 
					1809e858bb | ||
| 
						 | 
					2bbc970e10 | ||
| 
						 | 
					da8348e938 | ||
| 
						 | 
					ef16f45081 | ||
| 
						 | 
					4d692e1ba0 | ||
| 
						 | 
					6577e16920 | ||
| 
						 | 
					3fc378aa0b | ||
| 
						 | 
					f2bfbcef76 | ||
| 
						 | 
					6713a4835f | ||
| 
						 | 
					46ceb15c39 | ||
| 
						 | 
					109d3123c3 | ||
| 
						 | 
					63077bd40c | ||
| 
						 | 
					df364f1b00 | ||
| 
						 | 
					bc767216d9 | ||
| 
						 | 
					cacd830f02 | ||
| 
						 | 
					eda52e175a | ||
| 
						 | 
					665560e9a4 | ||
| 
						 | 
					c4fc8b5bf4 | ||
| 
						 | 
					9c52d2cc75 | ||
| 
						 | 
					0f814687b9 | ||
| 
						 | 
					f0eae953e2 | ||
| 
						 | 
					298a2f9e58 | ||
| 
						 | 
					ac0d0a5ecd | ||
| 
						 | 
					f15390bdb4 | ||
| 
						 | 
					d095b68d63 | ||
| 
						 | 
					508999fa7d | ||
| 
						 | 
					210a21bc8d | ||
| 
						 | 
					678c1e025b | ||
| 
						 | 
					1ab61a9179 | ||
| 
						 | 
					d6dda126b7 | ||
| 
						 | 
					7771b6c5b5 | ||
| 
						 | 
					4843acc868 | ||
| 
						 | 
					9e0aad9fd6 | ||
| 
						 | 
					1c7a0e2856 | ||
| 
						 | 
					abd23881c1 | ||
| 
						 | 
					d1739eb2d6 | ||
| 
						 | 
					2faa930bb0 | ||
| 
						 | 
					e14f4aab0a | ||
| 
						 | 
					c842261b1b | ||
| 
						 | 
					df368ecce4 | ||
| 
						 | 
					1e6bccc240 | ||
| 
						 | 
					d3adc3d3ed | ||
| 
						 | 
					10e7d6d526 | ||
| 
						 | 
					8d472bdd84 | ||
| 
						 | 
					430d7afd80 | ||
| 
						 | 
					ca982e4870 | ||
| 
						 | 
					d5f686d808 | ||
| 
						 | 
					08e1cbc62c | ||
| 
						 | 
					b6b4fdc9e2 | ||
| 
						 | 
					dd55880644 | ||
| 
						 | 
					bd1640bb01 | ||
| 
						 | 
					081991ac01 | ||
| 
						 | 
					8a85c341fe | ||
| 
						 | 
					bcfea9fb25 | ||
| 
						 | 
					f3f52d7f45 | ||
| 
						 | 
					8845420f4e | ||
| 
						 | 
					d735c64905 | ||
| 
						 | 
					955d465c2c | ||
| 
						 | 
					8c521c7a34 | ||
| 
						 | 
					77475142ec | ||
| 
						 | 
					90fac84066 | ||
| 
						 | 
					64674bcc8c | ||
| 
						 | 
					1dc2d655ad | ||
| 
						 | 
					863d2b196f | ||
| 
						 | 
					c57bc2dc51 | ||
| 
						 | 
					6c0dcdc211 | ||
| 
						 | 
					28ded31b97 | ||
| 
						 | 
					0fc07a0f9c | ||
| 
						 | 
					823a67b0a9 | ||
| 
						 | 
					60a938c6bc | ||
| 
						 | 
					3a87a9b9db | ||
| 
						 | 
					ae44fc1ec4 | 
@@ -15,3 +15,6 @@ cctest.a
 | 
				
			|||||||
libcrypto.so.*
 | 
					libcrypto.so.*
 | 
				
			||||||
libssl.so.*
 | 
					libssl.so.*
 | 
				
			||||||
libcrypto.sha1
 | 
					libcrypto.sha1
 | 
				
			||||||
 | 
					libcrypto.a.sha1
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										131
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										131
									
								
								CHANGES
									
									
									
									
									
								
							@@ -2,6 +2,137 @@
 | 
				
			|||||||
 OpenSSL CHANGES
 | 
					 OpenSSL CHANGES
 | 
				
			||||||
 _______________
 | 
					 _______________
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Changes between 0.9.7g and 0.9.7h  [XX xxx XXXX]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Minimal support for X9.31 signatures and PSS padding modes. This is
 | 
				
			||||||
 | 
					     mainly for FIPS compliance and not fully integrated at this stage.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) For DSA signing, unless DSA_FLAG_NO_EXP_CONSTTIME is set, perform
 | 
				
			||||||
 | 
					     the exponentiation using a fixed-length exponent.  (Otherwise,
 | 
				
			||||||
 | 
					     the information leaked through timing could expose the secret key
 | 
				
			||||||
 | 
					     after many signatures; cf. Bleichenbacher's attack on DSA with
 | 
				
			||||||
 | 
					     biased k.)
 | 
				
			||||||
 | 
					     [Bodo Moeller]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Make a new fixed-window mod_exp implementation the default for
 | 
				
			||||||
 | 
					     RSA, DSA, and DH private-key operations so that the sequence of
 | 
				
			||||||
 | 
					     squares and multiplies and the memory access pattern are
 | 
				
			||||||
 | 
					     independent of the particular secret key.  This will mitigate
 | 
				
			||||||
 | 
					     cache-timing and potential related attacks.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     BN_mod_exp_mont_consttime() is the new exponentiation implementation,
 | 
				
			||||||
 | 
					     and this is automatically used by BN_mod_exp_mont() if the new flag
 | 
				
			||||||
 | 
					     BN_FLG_EXP_CONSTTIME is set for the exponent.  RSA, DSA, and DH
 | 
				
			||||||
 | 
					     will use this BN flag for private exponents unless the flag
 | 
				
			||||||
 | 
					     RSA_FLAG_NO_EXP_CONSTTIME, DSA_FLAG_NO_EXP_CONSTTIME, or
 | 
				
			||||||
 | 
					     DH_FLAG_NO_EXP_CONSTTIME, respectively, is set.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     [Matthew D Wood (Intel Corp), with some changes by Bodo Moeller]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Change the client implementation for SSLv23_method() and
 | 
				
			||||||
 | 
					     SSLv23_client_method() so that is uses the SSL 3.0/TLS 1.0
 | 
				
			||||||
 | 
					     Client Hello message format if the SSL_OP_NO_SSLv2 option is set.
 | 
				
			||||||
 | 
					     (Previously, the SSL 2.0 backwards compatible Client Hello
 | 
				
			||||||
 | 
					     message format would be used even with SSL_OP_NO_SSLv2.)
 | 
				
			||||||
 | 
					     [Bodo Moeller]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Add support for smime-type MIME parameter in S/MIME messages which some
 | 
				
			||||||
 | 
					     clients need.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) New function BN_MONT_CTX_set_locked() to set montgomery parameters in
 | 
				
			||||||
 | 
					     a threadsafe manner. Modify rsa code to use new function and add calls
 | 
				
			||||||
 | 
					     to dsa and dh code (which had race conditions before).
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Include the fixed error library code in the C error file definitions
 | 
				
			||||||
 | 
					     instead of fixing them up at runtime. This keeps the error code
 | 
				
			||||||
 | 
					     structures constant.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Changes between 0.9.7f and 0.9.7g  [11 Apr 2005]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Fixes for newer kerberos headers. NB: the casts are needed because
 | 
				
			||||||
 | 
					     the 'length' field is signed on one version and unsigned on another
 | 
				
			||||||
 | 
					     with no (?) obvious way to tell the difference, without these VC++
 | 
				
			||||||
 | 
					     complains. Also the "definition" of FAR (blank) is no longer included
 | 
				
			||||||
 | 
					     nor is the error ENOMEM. KRB5_PRIVATE has to be set to 1 to pick up
 | 
				
			||||||
 | 
					     some needed definitions.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Undo Cygwin change.
 | 
				
			||||||
 | 
					     [Ulf M<>ller]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Added support for proxy certificates according to RFC 3820.
 | 
				
			||||||
 | 
					     Because they may be a security thread to unaware applications,
 | 
				
			||||||
 | 
					     they must be explicitely allowed in run-time.  See
 | 
				
			||||||
 | 
					     docs/HOWTO/proxy_certificates.txt for further information.
 | 
				
			||||||
 | 
					     [Richard Levitte]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Changes between 0.9.7e and 0.9.7f  [22 Mar 2005]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Use (SSL_RANDOM_VALUE - 4) bytes of pseudo random data when generating
 | 
				
			||||||
 | 
					     server and client random values. Previously
 | 
				
			||||||
 | 
					     (SSL_RANDOM_VALUE - sizeof(time_t)) would be used which would result in
 | 
				
			||||||
 | 
					     less random data when sizeof(time_t) > 4 (some 64 bit platforms).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     This change has negligible security impact because:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     1. Server and client random values still have 24 bytes of pseudo random
 | 
				
			||||||
 | 
					        data.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     2. Server and client random values are sent in the clear in the initial
 | 
				
			||||||
 | 
					        handshake.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     3. The master secret is derived using the premaster secret (48 bytes in
 | 
				
			||||||
 | 
					        size for static RSA ciphersuites) as well as client server and random
 | 
				
			||||||
 | 
					        values.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     The OpenSSL team would like to thank the UK NISCC for bringing this issue
 | 
				
			||||||
 | 
					     to our attention. 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					     [Stephen Henson, reported by UK NISCC]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Use Windows randomness collection on Cygwin.
 | 
				
			||||||
 | 
					     [Ulf M<>ller]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Fix hang in EGD/PRNGD query when communication socket is closed
 | 
				
			||||||
 | 
					     prematurely by EGD/PRNGD.
 | 
				
			||||||
 | 
					     [Darren Tucker <dtucker@zip.com.au> via Lutz J<>nicke, resolves #1014]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Prompt for pass phrases when appropriate for PKCS12 input format.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Back-port of selected performance improvements from development
 | 
				
			||||||
 | 
					     branch, as well as improved support for PowerPC platforms.
 | 
				
			||||||
 | 
					     [Andy Polyakov]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Add lots of checks for memory allocation failure, error codes to indicate
 | 
				
			||||||
 | 
					     failure and freeing up memory if a failure occurs.
 | 
				
			||||||
 | 
					     [Nauticus Networks SSL Team <openssl@nauticusnet.com>, Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Add new -passin argument to dgst.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Perform some character comparisons of different types in X509_NAME_cmp:
 | 
				
			||||||
 | 
					     this is needed for some certificates that reencode DNs into UTF8Strings
 | 
				
			||||||
 | 
					     (in violation of RFC3280) and can't or wont issue name rollover
 | 
				
			||||||
 | 
					     certificates.
 | 
				
			||||||
 | 
					     [Steve Henson]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  *) Make an explicit check during certificate validation to see that
 | 
				
			||||||
 | 
					     the CA setting in each certificate on the chain is correct.  As a
 | 
				
			||||||
 | 
					     side effect always do the following basic checks on extensions,
 | 
				
			||||||
 | 
					     not just when there's an associated purpose to the check:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      - if there is an unhandled critical extension (unless the user
 | 
				
			||||||
 | 
					        has chosen to ignore this fault)
 | 
				
			||||||
 | 
					      - if the path length has been exceeded (if one is set at all)
 | 
				
			||||||
 | 
					      - that certain extensions fit the associated purpose (if one has
 | 
				
			||||||
 | 
					        been given)
 | 
				
			||||||
 | 
					     [Richard Levitte]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Changes between 0.9.7d and 0.9.7e  [25 Oct 2004]
 | 
					 Changes between 0.9.7d and 0.9.7e  [25 Oct 2004]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  *) Avoid a race condition when CRLs are checked in a multi threaded 
 | 
					  *) Avoid a race condition when CRLs are checked in a multi threaded 
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										134
									
								
								Configure
									
									
									
									
									
								
							
							
						
						
									
										134
									
								
								Configure
									
									
									
									
									
								
							@@ -169,9 +169,19 @@ my %table=(
 | 
				
			|||||||
# 7_x86) /usr/ccs/bin/as fails to assemble with "Illegal mnemonic"
 | 
					# 7_x86) /usr/ccs/bin/as fails to assemble with "Illegal mnemonic"
 | 
				
			||||||
# error message.
 | 
					# error message.
 | 
				
			||||||
"solaris-x86-gcc","gcc:-O3 -fomit-frame-pointer -m486 -Wall -DL_ENDIAN -DOPENSSL_NO_INLINE_ASM::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-x86-gcc","gcc:-O3 -fomit-frame-pointer -m486 -Wall -DL_ENDIAN -DOPENSSL_NO_INLINE_ASM::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					# -shared -static-libgcc might appear controversial, but modules taken
 | 
				
			||||||
 | 
					# from static libgcc do not have relocations and linking them into our
 | 
				
			||||||
 | 
					# shared objects doesn't have any negative side-effects. On the contrary,
 | 
				
			||||||
 | 
					# doing so makes it possible to use gcc shared build with Sun C. Given
 | 
				
			||||||
 | 
					# that gcc generates faster code [thanks to inline assembler], I would
 | 
				
			||||||
 | 
					# actually recommend to consider using gcc shared build even with vendor
 | 
				
			||||||
 | 
					# compiler:-)
 | 
				
			||||||
 | 
					#						<appro@fy.chalmers.se>
 | 
				
			||||||
 | 
					"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 RC4_CHAR BF_PTR2 DES_INT DES_UNROLL:asm/x86_64-gcc.o::::::asm/rc4-x86_64.o:::dlfcn:solaris-shared:-fPIC:-m64 -shared -static-libgcc:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### 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::::::::::dlfcn:solaris-shared:-KPIC::.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::::::::::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 RC4_CHAR BF_PTR2 DES_INT DES_UNROLL::::::::::dlfcn:solaris-shared:-KPIC:-xarch=amd64 -G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### 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::::::::::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::::::::::dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
@@ -190,17 +200,17 @@ my %table=(
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#### SPARC Solaris with Sun C setups
 | 
					#### SPARC Solaris with Sun C setups
 | 
				
			||||||
# DO NOT use /xO[34] on sparc with SC3.0.  It is broken, and will not pass the tests
 | 
					# DO NOT use /xO[34] on sparc with SC3.0.  It is broken, and will not pass the tests
 | 
				
			||||||
"solaris-sparc-sc3","cc:-fast -O -Xa -DB_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL BF_PTR::::::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-sparc-sc3","cc:-fast -O -Xa -DB_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL BF_PTR::::::::::dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# SC4.0 doesn't pass 'make test', upgrade to SC5.0 or SC4.2.
 | 
					# SC4.0 doesn't pass 'make test', upgrade to SC5.0 or SC4.2.
 | 
				
			||||||
# SC4.2 is ok, better than gcc even on bn as long as you tell it -xarch=v8
 | 
					# SC4.2 is ok, better than gcc even on bn as long as you tell it -xarch=v8
 | 
				
			||||||
# SC5.0 note: Compiler common patch 107357-01 or later is required!
 | 
					# SC5.0 note: Compiler common patch 107357-01 or later is required!
 | 
				
			||||||
"solaris-sparcv7-cc","cc:-xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR::::::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-sparcv7-cc","cc:-xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR::::::::::dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"solaris-sparcv8-cc","cc:-xarch=v8 -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8.o:::::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-sparcv8-cc","cc:-xarch=v8 -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8.o:::::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"solaris-sparcv9-cc","cc:-xtarget=ultra -xarch=v8plus -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK_LL DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8plus.o:::asm/md5-sparcv8plus.o::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"solaris-sparcv9-cc","cc:-xtarget=ultra -xarch=v8plus -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK_LL DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8plus.o:::asm/md5-sparcv8plus.o::::::dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"solaris64-sparcv9-cc","cc:-xtarget=ultra -xarch=v9 -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL BF_PTR::::asm/md5-sparcv9.o::::::dlfcn:solaris-shared:-KPIC:-xarch=v9:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):/usr/ccs/bin/ar rs",
 | 
					"solaris64-sparcv9-cc","cc:-xtarget=ultra -xarch=v9 -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL BF_PTR::::asm/md5-sparcv9.o::::::dlfcn:solaris-shared:-KPIC:-xarch=v9 -G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):/usr/ccs/bin/ar rs",
 | 
				
			||||||
####
 | 
					####
 | 
				
			||||||
"debug-solaris-sparcv8-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -xarch=v8 -g -O -xstrconst -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8.o:::::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-solaris-sparcv8-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -xarch=v8 -g -O -xstrconst -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8.o:::::::::dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"debug-solaris-sparcv9-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -xtarget=ultra -xarch=v8plus -g -O -xstrconst -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK_LL DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8plus.o:::asm/md5-sparcv8plus.o::::::dlfcn:solaris-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"debug-solaris-sparcv9-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -xtarget=ultra -xarch=v8plus -g -O -xstrconst -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK_LL DES_PTR DES_RISC1 DES_UNROLL BF_PTR:asm/sparcv8plus.o:::asm/md5-sparcv8plus.o::::::dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### SPARC Linux setups
 | 
					#### SPARC Linux setups
 | 
				
			||||||
"linux-sparcv7","gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT:::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR::",
 | 
					"linux-sparcv7","gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT:::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR::",
 | 
				
			||||||
@@ -261,56 +271,56 @@ my %table=(
 | 
				
			|||||||
#
 | 
					#
 | 
				
			||||||
#!#"hpux-parisc-cc","cc:-Ae +O3 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::::-ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl",
 | 
					#!#"hpux-parisc-cc","cc:-Ae +O3 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::::-ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl",
 | 
				
			||||||
# 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::::-ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc-cc-o4","cc:-Ae +O4 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::::-Wl,+cdp,../%3a,+cdp,./%3a,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux-parisc-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::::-Wl,+cdp,../%3a,+cdp,./%3a,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux64-parisc-cc","cc:-Ae +DD64 +O3 +ESlit -z -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::::::::::dlfcn:hpux64-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux64-parisc-cc","cc:-Ae +DD64 +O3 +ESlit -z -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::::::::::dlfcn:hpux-shared:+Z:+DD64 -b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# 64bit PARISC for GCC without optimization, which seems to make problems.
 | 
					# 64bit PARISC for GCC without optimization, which seems to make problems.
 | 
				
			||||||
# Submitted by <ross.alexander@uk.neceur.com>
 | 
					# Submitted by <ross.alexander@uk.neceur.com>
 | 
				
			||||||
"hpux64-parisc-gcc","gcc:-DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::::::::::dlfcn:hpux64-shared:-fpic::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux64-parisc-gcc","gcc:-DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::::::::::dlfcn:hpux-shared:-fpic:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"hpux64-parisc2-gcc","gcc:-O3 -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/pa-risc2W.o:::::::::dlfcn:hpux64-shared:-fpic::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux64-parisc2-gcc","gcc:-O3 -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/pa-risc2W.o:::::::::dlfcn:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# IA-64 targets
 | 
					# IA-64 targets
 | 
				
			||||||
"hpux-ia64-cc","cc:-Ae +DD32 +O3 +Olit=all -z -DB_ENDIAN::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/ia64-cpp.o:::::::::dlfcn:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-ia64-cc","cc:-Ae +DD32 +O3 +Olit=all -z -DB_ENDIAN::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldl:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/ia64-cpp.o::::asm/sha1-ia64.o::asm/rc4-ia64.o:::dlfcn:hpux-shared:+Z:-b:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# Frank Geurts <frank.geurts@nl.abnamro.com> has patiently assisted with
 | 
					# Frank Geurts <frank.geurts@nl.abnamro.com> has patiently assisted with
 | 
				
			||||||
# with debugging of the following config.
 | 
					# with debugging of the following config.
 | 
				
			||||||
"hpux64-ia64-cc","cc:-Ae +DD64 +O3 +Olit=all -z -DB_ENDIAN::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/ia64-cpp.o:::::::::dlfcn:hpux64-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux64-ia64-cc","cc:-Ae +DD64 +O3 +Olit=all -z -DB_ENDIAN::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/ia64-cpp.o::::asm/sha1-ia64.o::asm/rc4-ia64.o:::dlfcn:hpux-shared:+Z:+DD64 -b:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# 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::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc-cc","cc:+O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-Wl,+cdp,../%3a,+cdp,./%3a,+s,+b,\$(INSTALLTOP)/lib -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::::::::::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:asm/pa-risc2.o:::::::::dl:hpux-shared:+Z::.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,+cdp,../%3a,+cdp,./%3a,+s,+b,\$(INSTALLTOP)/lib -ldld:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/pa-risc2.o:::::::::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:asm/pa-risc2W.o:::::::::dlfcn:hpux64-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux64-parisc2-cc","cc:+DD64 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:asm/pa-risc2W.o:::::::::dlfcn:hpux-shared:+Z:+DD64 -b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# Isn't the line below meaningless? HP-UX cc optimizes for host by default.
 | 
					# Isn't the line below meaningless? HP-UX cc optimizes for host by default.
 | 
				
			||||||
# hpux-parisc1_0-cc with +DAportable flag would make more sense. <appro>
 | 
					# hpux-parisc1_0-cc with +DAportable flag would make more sense. <appro>
 | 
				
			||||||
"hpux-parisc1_1-cc","cc:+DA1.1 +DS1.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::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-parisc1_1-cc","cc:+DA1.1 +DS1.1 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+cdp,../%3a,+cdp,./%3a,+s,+b,\$(INSTALLTOP)/lib -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::::::::::dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# HPUX 9.X config.
 | 
					# HPUX 9.X config.
 | 
				
			||||||
# Don't use the bundled cc.  It is broken.  Use HP ANSI C if possible, or
 | 
					# Don't use the bundled cc.  It is broken.  Use HP ANSI C if possible, or
 | 
				
			||||||
# egcs.  gcc 2.8.1 is also broken.
 | 
					# egcs.  gcc 2.8.1 is also broken.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"hpux-cc",	"cc:-DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O3 -z::(unknown)::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-cc",	"cc:-DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O3 -z::(unknown)::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# If hpux-cc fails (e.g. during "make test"), try the next one; otherwise,
 | 
					# If hpux-cc fails (e.g. during "make test"), try the next one; otherwise,
 | 
				
			||||||
# please report your OS and compiler version to the openssl-bugs@openssl.org
 | 
					# please report your OS and compiler version to the openssl-bugs@openssl.org
 | 
				
			||||||
# mailing list.
 | 
					# mailing list.
 | 
				
			||||||
"hpux-brokencc",	"cc:-DB_ENDIAN -DBN_DIV2W -Ae +ESlit +O2 -z::(unknown)::-Wl,+s -ldld:DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-brokencc",	"cc:-DB_ENDIAN -DBN_DIV2W -Ae +ESlit +O2 -z::(unknown)::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"hpux-gcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown)::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-gcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown)::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# If hpux-gcc fails, try this one:
 | 
					# If hpux-gcc fails, try this one:
 | 
				
			||||||
"hpux-brokengcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown)::-Wl,+s -ldld:DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux-brokengcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown)::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# HPUX 9.X on Motorola 68k platforms with gcc
 | 
					# HPUX 9.X on Motorola 68k platforms with gcc
 | 
				
			||||||
"hpux-m68k-gcc",  "gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown):::BN_LLONG DES_PTR DES_UNROLL:::::::::::::",
 | 
					"hpux-m68k-gcc",  "gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown):::BN_LLONG DES_PTR DES_UNROLL:::::::::::::",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# HPUX 10.X config.  Supports threads.
 | 
					# HPUX 10.X config.  Supports threads.
 | 
				
			||||||
"hpux10-cc",	"cc:-DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O3 -z::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux10-cc",	"cc:-DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O3 -z::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# If hpux10-cc fails, try this one (if still fails, try deleting BN_LLONG):
 | 
					# If hpux10-cc fails, try this one (if still fails, try deleting BN_LLONG):
 | 
				
			||||||
"hpux10-brokencc",	"cc:-DB_ENDIAN -DBN_DIV2W -Ae +ESlit +O2 -z::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux10-brokencc",	"cc:-DB_ENDIAN -DBN_DIV2W -Ae +ESlit +O2 -z::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"hpux10-gcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux10-gcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
# If hpux10-gcc fails, try this one:
 | 
					# If hpux10-gcc fails, try this one:
 | 
				
			||||||
"hpux10-brokengcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::-D_REENTRANT::-Wl,+s -ldld:DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC::.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"hpux10-brokengcc",	"gcc:-DB_ENDIAN -DBN_DIV2W -O3::-D_REENTRANT::-Wl,+s,+b,\$(INSTALLTOP)/lib -ldld:DES_PTR DES_UNROLL DES_RISC1::::::::::dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# HPUX 11.X from www.globus.org.
 | 
					# HPUX 11.X from www.globus.org.
 | 
				
			||||||
# Only works on PA-RISC 2.0 cpus, and not optimized.  Why?
 | 
					# Only works on PA-RISC 2.0 cpus, and not optimized.  Why?
 | 
				
			||||||
@@ -393,13 +403,15 @@ my %table=(
 | 
				
			|||||||
"linux-aout",	"gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -m486 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_out_asm}",
 | 
					"linux-aout",	"gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -m486 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_out_asm}",
 | 
				
			||||||
"linux-mipsel",   "gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL DES_RISC2::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-mipsel",   "gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL DES_RISC2::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-mips",   "gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL DES_RISC2::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-mips",   "gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL DES_RISC2::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-ppc",    "gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-ppc",    "gcc:-DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL:asm/linux_ppc32.o:::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					# -bpowerpc64-linux is transient option, -m64 should be the one to use...
 | 
				
			||||||
 | 
					"linux-ppc64",  "gcc:-bpowerpc64-linux -DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL:asm/linux_ppc64.o:::::::::dlfcn:linux-shared:-fPIC:-bpowerpc64-linux:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-m68k",   "gcc:-DB_ENDIAN -DTERMIO -O2 -fomit-frame-pointer -Wall::-D_REENTRANT:::BN_LLONG::",
 | 
					"linux-m68k",   "gcc:-DB_ENDIAN -DTERMIO -O2 -fomit-frame-pointer -Wall::-D_REENTRANT:::BN_LLONG::",
 | 
				
			||||||
"linux-s390",	"gcc:-DB_ENDIAN -DTERMIO -DNO_ASM -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-s390",	"gcc:-DB_ENDIAN -DTERMIO -DNO_ASM -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-s390x",	"gcc:-DB_ENDIAN -DTERMIO -DNO_ASM -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-s390x",	"gcc:-DB_ENDIAN -DTERMIO -DNO_ASM -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-ia64",   "gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR:asm/ia64.o:::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-ia64",   "gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR:asm/ia64.o::::asm/sha1-ia64.o::asm/rc4-ia64.o:::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-ia64-ecc",   "ecc:-DL_ENDIAN -DTERMIO -O2 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR:asm/ia64.o:::::::::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 RC4_CHAR:asm/ia64.o::::asm/sha1-ia64.o::asm/rc4-ia64.o:::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"linux-x86_64", "gcc:-m64 -DL_ENDIAN -DTERMIO -O3 -Wall -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR BF_PTR2 DES_INT DES_UNROLL:asm/x86_64-gcc.o:::::::::dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"linux-x86_64", "gcc:-m64 -DL_ENDIAN -DTERMIO -O3 -Wall -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR BF_PTR2 DES_INT DES_UNROLL:asm/x86_64-gcc.o::::::asm/rc4-x86_64.o:::dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"NetBSD-sparc",	"gcc:-DTERMIOS -O3 -fomit-frame-pointer -mv8 -Wall -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX DES_UNROLL::::::::::dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"NetBSD-sparc",	"gcc:-DTERMIOS -O3 -fomit-frame-pointer -mv8 -Wall -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX DES_UNROLL::::::::::dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"NetBSD-m68",	"gcc:-DTERMIOS -O3 -fomit-frame-pointer -Wall -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX DES_UNROLL::::::::::dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"NetBSD-m68",	"gcc:-DTERMIOS -O3 -fomit-frame-pointer -Wall -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX DES_UNROLL::::::::::dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
"NetBSD-x86",	"gcc:-DTERMIOS -O3 -fomit-frame-pointer -m486 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					"NetBSD-x86",	"gcc:-DTERMIOS -O3 -fomit-frame-pointer -m486 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
@@ -422,7 +434,9 @@ my %table=(
 | 
				
			|||||||
"qnx6",	"cc:-DL_ENDIAN -DTERMIOS::(unknown)::-lsocket:${x86_gcc_des} ${x86_gcc_opts}:",
 | 
					"qnx6",	"cc:-DL_ENDIAN -DTERMIOS::(unknown)::-lsocket:${x86_gcc_des} ${x86_gcc_opts}:",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Linux on ARM
 | 
					# Linux on ARM
 | 
				
			||||||
"linux-elf-arm","gcc:-DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
					# ARM comes in both little- and big-endian flavors. The following line is
 | 
				
			||||||
 | 
					# endian neutral, but ./config is free to throw in -D[BL]_ENDIAN...
 | 
				
			||||||
 | 
					"linux-elf-arm","gcc:-DTERMIO -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG::::::::::dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# SCO/Caldera targets.
 | 
					# SCO/Caldera targets.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
@@ -449,11 +463,10 @@ my %table=(
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# IBM's AIX.
 | 
					# IBM's AIX.
 | 
				
			||||||
"aix-cc",   "cc:-O -DB_ENDIAN -qmaxmem=16384::(unknown):AIX::BN_LLONG RC4_CHAR:::",
 | 
					"aix3-cc",    "cc:-O -DB_ENDIAN -qmaxmem=16384::(unknown):AIX::BN_LLONG RC4_CHAR:::",
 | 
				
			||||||
"aix-gcc",  "gcc:-O3 -DB_ENDIAN::(unknown):AIX::BN_LLONG RC4_CHAR:::",
 | 
					"aix-gcc",    "gcc:-O3 -DB_ENDIAN::-D_THREAD_SAFE:AIX::BN_LLONG RC4_CHAR:asm/aix_ppc32.o:::::::::dlfcn:",
 | 
				
			||||||
"aix43-cc",   "cc:-O -DAIX -DB_ENDIAN -qmaxmem=16384::(unknown):::BN_LLONG RC4_CHAR::::::::::dlfcn:aix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::",
 | 
					"aix-cc",     "cc:-q32 -O -DB_ENDIAN -qmaxmem=16384::-qthreaded:AIX::BN_LLONG RC4_CHAR:asm/aix_ppc32.o:::::::::dlfcn:aix-shared::-q32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X 32",
 | 
				
			||||||
"aix43-gcc",  "gcc:-O1 -DAIX -DB_ENDIAN::(unknown):::BN_LLONG RC4_CHAR::::::::::dlfcn:",
 | 
					"aix64-cc",   "cc:-q64 -O -DB_ENDIAN -qmaxmem=16384::-qthreaded:AIX::SIXTY_FOUR_BIT_LONG RC4_CHAR:asm/aix_ppc64.o:::::::::dlfcn:aix-shared::-q64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X 64",
 | 
				
			||||||
"aix64-cc",   "cc:-O -DAIX -DB_ENDIAN -qmaxmem=16384 -q64::(unknown):::SIXTY_FOUR_BIT_LONG RC4_CHAR::::::::::dlfcn:aix-shared::-q64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X 64",
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# Cray T90 and similar (SDSC)
 | 
					# Cray T90 and similar (SDSC)
 | 
				
			||||||
@@ -516,14 +529,14 @@ my %table=(
 | 
				
			|||||||
"BC-16","bcc:::(unknown):WIN16::BN_LLONG DES_PTR RC4_INDEX SIXTEEN_BIT:::",
 | 
					"BC-16","bcc:::(unknown):WIN16::BN_LLONG DES_PTR RC4_INDEX SIXTEEN_BIT:::",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# MinGW
 | 
					# MinGW
 | 
				
			||||||
"mingw", "gcc:-DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -mno-cygwin -Wall:::MINGW32:-mno-cygwin -lwsock32 -lgdi32:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_out_asm}:win32::::.dll",
 | 
					"mingw", "gcc:-DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -mno-cygwin -Wall -D_WIN32_WINNT=0x333:::MINGW32:-lwsock32 -lgdi32:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts} EXPORT_VAR_AS_FN:${x86_out_asm}: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}::::::::::win32",
 | 
					"UWIN", "cc:-DTERMIOS -DL_ENDIAN -O -Wall:::UWIN::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::win32",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Cygwin
 | 
					# Cygwin
 | 
				
			||||||
"Cygwin-pre1.3", "gcc:-DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O3 -m486 -Wall::(unknown):CYGWIN32::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::win32",
 | 
					"Cygwin-pre1.3", "gcc:-DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O3 -m486 -Wall::(unknown):CYGWIN32::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::win32",
 | 
				
			||||||
"Cygwin", "gcc:-DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall:::CYGWIN32::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_out_asm}:win32:cygwin-shared:::.dll",
 | 
					"Cygwin", "gcc:-DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall:::CYGWIN32::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_out_asm}:dlfcn:cygwin-shared:-D_WINDLL::.dll.a",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# DJGPP
 | 
					# DJGPP
 | 
				
			||||||
"DJGPP", "gcc:-I/dev/env/WATT_ROOT/inc -DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O2 -Wall:::MSDOS:-L/dev/env/WATT_ROOT/lib -lwatt:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::",
 | 
					"DJGPP", "gcc:-I/dev/env/WATT_ROOT/inc -DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O2 -Wall:::MSDOS:-L/dev/env/WATT_ROOT/lib -lwatt:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}::::::::::",
 | 
				
			||||||
@@ -549,7 +562,7 @@ 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:::",
 | 
					"rhapsody-ppc-cc","cc:-O3 -DB_ENDIAN::(unknown):MACOSX_RHAPSODY::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::",
 | 
				
			||||||
"darwin-ppc-cc","cc:-O3 -fomit-frame-pointer -fno-common -DB_ENDIAN::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::::::::::darwin-shared:-fPIC::.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"darwin-ppc-cc","cc:-O3 -fomit-frame-pointer -DB_ENDIAN::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:asm/osx_ppc32.o:::::::::dlfcn:darwin-shared:-fPIC -fno-common::.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
"darwin-i386-cc","cc:-O3 -fomit-frame-pointer -fno-common -DB_ENDIAN::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::::::::::darwin-shared:-fPIC::.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
					"darwin-i386-cc","cc:-O3 -fomit-frame-pointer -fno-common -DB_ENDIAN::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::::::::::darwin-shared:-fPIC::.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
##### A/UX
 | 
					##### A/UX
 | 
				
			||||||
@@ -865,7 +878,7 @@ PROCESS_ARGS:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			die "target already defined - $target\n" if ($target ne "");
 | 
								die "target already defined - $target (offending arg: $_)\n" if ($target ne "");
 | 
				
			||||||
			$target=$_;
 | 
								$target=$_;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		unless ($_ eq $target) {
 | 
							unless ($_ eq $target) {
 | 
				
			||||||
@@ -936,8 +949,7 @@ print "Configuring for $target\n";
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
my $IsWindows=scalar grep /^$target$/,@WinTargets;
 | 
					my $IsWindows=scalar grep /^$target$/,@WinTargets;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$exe_ext=".exe" if ($target eq "Cygwin");
 | 
					$exe_ext=".exe" if ($target eq "Cygwin" || $target eq "DJGPP" || $target eq "mingw");
 | 
				
			||||||
$exe_ext=".exe" if ($target eq "DJGPP");
 | 
					 | 
				
			||||||
$exe_ext=".pm" if ($target eq "vos-gcc" or $target eq "debug-vos-gcc" or $target eq "vos-vcc" or $target eq "debug-vos-vcc");
 | 
					$exe_ext=".pm" if ($target eq "vos-gcc" or $target eq "debug-vos-gcc" or $target eq "vos-vcc" or $target eq "debug-vos-vcc");
 | 
				
			||||||
$openssldir="/usr/local/ssl" if ($openssldir eq "" and $prefix eq "");
 | 
					$openssldir="/usr/local/ssl" if ($openssldir eq "" and $prefix eq "");
 | 
				
			||||||
$prefix=$openssldir if $prefix eq "";
 | 
					$prefix=$openssldir if $prefix eq "";
 | 
				
			||||||
@@ -956,6 +968,7 @@ $openssldir=$prefix . "/" . $openssldir if $openssldir !~ /(^\/|^[a-zA-Z]:[\\\/]
 | 
				
			|||||||
print "IsWindows=$IsWindows\n";
 | 
					print "IsWindows=$IsWindows\n";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
my @fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
					my @fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
				
			||||||
 | 
					for (@fields) { s/%([\dA-Fa-f]{2})/chr(hex($1))/eg; }
 | 
				
			||||||
my $cc = $fields[$idx_cc];
 | 
					my $cc = $fields[$idx_cc];
 | 
				
			||||||
my $cflags = $fields[$idx_cflags];
 | 
					my $cflags = $fields[$idx_cflags];
 | 
				
			||||||
my $unistd = $fields[$idx_unistd];
 | 
					my $unistd = $fields[$idx_unistd];
 | 
				
			||||||
@@ -1014,7 +1027,7 @@ else
 | 
				
			|||||||
			if $withargs{"krb5-dir"} eq "";
 | 
								if $withargs{"krb5-dir"} eq "";
 | 
				
			||||||
		$withargs{"krb5-lib"} = "-L".$withargs{"krb5-dir"}.
 | 
							$withargs{"krb5-lib"} = "-L".$withargs{"krb5-dir"}.
 | 
				
			||||||
			"/lib -lgssapi -lkrb5 -lcom_err"
 | 
								"/lib -lgssapi -lkrb5 -lcom_err"
 | 
				
			||||||
			if $withargs{"krb5-lib"} eq "";
 | 
								if $withargs{"krb5-lib"} eq "" && !$IsWindows;
 | 
				
			||||||
		$cflags="-DKRB5_HEIMDAL $cflags";
 | 
							$cflags="-DKRB5_HEIMDAL $cflags";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if ($withargs{"krb5-flavor"} =~ /^[Mm][Ii][Tt]/)
 | 
						if ($withargs{"krb5-flavor"} =~ /^[Mm][Ii][Tt]/)
 | 
				
			||||||
@@ -1023,7 +1036,7 @@ else
 | 
				
			|||||||
			if $withargs{"krb5-dir"} eq "";
 | 
								if $withargs{"krb5-dir"} eq "";
 | 
				
			||||||
		$withargs{"krb5-lib"} = "-L".$withargs{"krb5-dir"}.
 | 
							$withargs{"krb5-lib"} = "-L".$withargs{"krb5-dir"}.
 | 
				
			||||||
			"/lib -lgssapi_krb5 -lkrb5 -lcom_err -lk5crypto"
 | 
								"/lib -lgssapi_krb5 -lkrb5 -lcom_err -lk5crypto"
 | 
				
			||||||
			if $withargs{"krb5-lib"} eq "";
 | 
								if $withargs{"krb5-lib"} eq "" && !$IsWindows;
 | 
				
			||||||
		$cflags="-DKRB5_MIT $cflags";
 | 
							$cflags="-DKRB5_MIT $cflags";
 | 
				
			||||||
		$withargs{"krb5-flavor"} =~ s/^[Mm][Ii][Tt][._-]*//;
 | 
							$withargs{"krb5-flavor"} =~ s/^[Mm][Ii][Tt][._-]*//;
 | 
				
			||||||
		if ($withargs{"krb5-flavor"} =~ /^1[._-]*[01]/)
 | 
							if ($withargs{"krb5-flavor"} =~ /^1[._-]*[01]/)
 | 
				
			||||||
@@ -1042,7 +1055,7 @@ else
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	$withargs{"krb5-lib"} .= " -lresolv"
 | 
						$withargs{"krb5-lib"} .= " -lresolv"
 | 
				
			||||||
		if ("$lresolv" ne "");
 | 
							if ("$lresolv" ne "" && !$IsWindows);
 | 
				
			||||||
	$withargs{"krb5-include"} = "-I".$withargs{"krb5-dir"}."/include"
 | 
						$withargs{"krb5-include"} = "-I".$withargs{"krb5-dir"}."/include"
 | 
				
			||||||
		if $withargs{"krb5-include"} eq "" &&
 | 
							if $withargs{"krb5-include"} eq "" &&
 | 
				
			||||||
		   $withargs{"krb5-dir"} ne "";
 | 
							   $withargs{"krb5-dir"} ne "";
 | 
				
			||||||
@@ -1138,7 +1151,7 @@ if (!$no_shared)
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	if ($shared_cflag ne "")
 | 
						if ($shared_cflag ne "")
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		$cflags = "$shared_cflag $cflags";
 | 
							$cflags = "$shared_cflag -DOPENSSL_PIC $cflags";
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1160,15 +1173,27 @@ if ($ranlib eq "")
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
$bn_obj = $bn_asm unless $bn_obj ne "";
 | 
					$bn_obj = $bn_asm unless $bn_obj ne "";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					my $fips_des_obj;
 | 
				
			||||||
 | 
					my $fips_aes_obj;
 | 
				
			||||||
 | 
					my $fips_sha1_obj;
 | 
				
			||||||
if ($fips)
 | 
					if ($fips)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
 | 
						if ($des_obj =~ /\-elf\.o$/)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							$fips_des_obj='asm/fips-dx86-elf.o';
 | 
				
			||||||
 | 
							$openssl_other_defines.="#define OPENSSL_FIPS_DES_ASM\n";
 | 
				
			||||||
 | 
							$fips_aes_obj='asm/fips-ax86-elf.o';
 | 
				
			||||||
 | 
							$openssl_other_defines.="#define OPENSSL_FIPS_AES_ASM\n";
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						else	{
 | 
				
			||||||
 | 
							$fips_des_obj=$fips_des_enc;
 | 
				
			||||||
 | 
							$fips_aes_obj='fips_aes_core.o';
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						$fips_sha1_obj='asm/fips-sx86-elf.o' if ($sha1_obj =~ /\-elf\.o$/);
 | 
				
			||||||
	$des_obj=$sha1_obj="";
 | 
						$des_obj=$sha1_obj="";
 | 
				
			||||||
	$openssl_other_defines.="#define OPENSSL_FIPS\n";
 | 
						$openssl_other_defines.="#define OPENSSL_FIPS\n";
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
$des_obj=$des_enc	unless (!$fips && $des_obj =~ /\.o$/);
 | 
					$des_obj=$des_enc	unless ($des_obj =~ /\.o$/);
 | 
				
			||||||
my $fips_des_obj='asm/fips-dx86-elf.o';
 | 
					 | 
				
			||||||
$fips_des_obj=$fips_des_enc unless $processor eq '386';
 | 
					 | 
				
			||||||
my $fips_sha1_obj='asm/sx86-elf.o' if $processor eq '386';
 | 
					 | 
				
			||||||
$bf_obj=$bf_enc		unless ($bf_obj =~ /\.o$/);
 | 
					$bf_obj=$bf_enc		unless ($bf_obj =~ /\.o$/);
 | 
				
			||||||
$cast_obj=$cast_enc	unless ($cast_obj =~ /\.o$/);
 | 
					$cast_obj=$cast_enc	unless ($cast_obj =~ /\.o$/);
 | 
				
			||||||
$rc4_obj=$rc4_enc	unless ($rc4_obj =~ /\.o$/);
 | 
					$rc4_obj=$rc4_enc	unless ($rc4_obj =~ /\.o$/);
 | 
				
			||||||
@@ -1268,6 +1293,7 @@ while (<IN>)
 | 
				
			|||||||
	s/^BN_ASM=.*$/BN_ASM= $bn_obj/;
 | 
						s/^BN_ASM=.*$/BN_ASM= $bn_obj/;
 | 
				
			||||||
	s/^DES_ENC=.*$/DES_ENC= $des_obj/;
 | 
						s/^DES_ENC=.*$/DES_ENC= $des_obj/;
 | 
				
			||||||
	s/^FIPS_DES_ENC=.*$/FIPS_DES_ENC= $fips_des_obj/;
 | 
						s/^FIPS_DES_ENC=.*$/FIPS_DES_ENC= $fips_des_obj/;
 | 
				
			||||||
 | 
						s/^FIPS_AES_ENC=.*$/FIPS_AES_ENC= $fips_aes_obj/;
 | 
				
			||||||
	s/^BF_ENC=.*$/BF_ENC= $bf_obj/;
 | 
						s/^BF_ENC=.*$/BF_ENC= $bf_obj/;
 | 
				
			||||||
	s/^CAST_ENC=.*$/CAST_ENC= $cast_obj/;
 | 
						s/^CAST_ENC=.*$/CAST_ENC= $cast_obj/;
 | 
				
			||||||
	s/^RC4_ENC=.*$/RC4_ENC= $rc4_obj/;
 | 
						s/^RC4_ENC=.*$/RC4_ENC= $rc4_obj/;
 | 
				
			||||||
@@ -1524,12 +1550,10 @@ EOF
 | 
				
			|||||||
		if $make_targets ne "";
 | 
							if $make_targets ne "";
 | 
				
			||||||
	if ( $perl =~ m@^/@) {
 | 
						if ( $perl =~ m@^/@) {
 | 
				
			||||||
	    &dofile("tools/c_rehash",$perl,'^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";');
 | 
						    &dofile("tools/c_rehash",$perl,'^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";');
 | 
				
			||||||
	    &dofile("apps/der_chop",$perl,'^#!/', '#!%s');
 | 
					 | 
				
			||||||
	    &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 . '";');
 | 
						    &dofile("tools/c_rehash",'/usr/local/bin/perl','^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";');
 | 
				
			||||||
	    &dofile("apps/der_chop",'/usr/local/bin/perl','^#!/', '#!%s');
 | 
					 | 
				
			||||||
	    &dofile("apps/CA.pl",'/usr/local/bin/perl','^#!/', '#!%s');
 | 
						    &dofile("apps/CA.pl",'/usr/local/bin/perl','^#!/', '#!%s');
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if ($depflags ne "" && !$make_depend) {
 | 
						if ($depflags ne "" && !$make_depend) {
 | 
				
			||||||
@@ -1637,12 +1661,13 @@ sub print_table_entry
 | 
				
			|||||||
	{
 | 
						{
 | 
				
			||||||
	my $target = shift;
 | 
						my $target = shift;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						my @fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
				
			||||||
 | 
						for (@fields) { s/%([\dA-Fa-f]{2})/chr(hex($1))/eg; }
 | 
				
			||||||
	(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 $bn_obj,my $des_obj,my $bf_obj,
 | 
						my $bn_ops,my $bn_obj,my $des_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 $dso_scheme,my $shared_target,my $shared_cflag,
 | 
						my $rc5_obj,my $dso_scheme,my $shared_target,my $shared_cflag,
 | 
				
			||||||
	my $shared_ldflag,my $shared_extension,my $ranlib,my $arflags)=
 | 
						my $shared_ldflag,my $shared_extension,my $ranlib,my $arflags)=@fields;
 | 
				
			||||||
	split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
					 | 
				
			||||||
			
 | 
								
 | 
				
			||||||
	print <<EOF
 | 
						print <<EOF
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1685,6 +1710,7 @@ sub test_sanity
 | 
				
			|||||||
	foreach $target (sort keys %table)
 | 
						foreach $target (sort keys %table)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		@fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
							@fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
 | 
				
			||||||
 | 
							for (@fields) { s/%([\dA-Fa-f]{2})/chr(hex($1))/eg; }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if ($fields[$idx_dso_scheme-1] =~ /^(dl|dlfcn|win32|vms)$/)
 | 
							if ($fields[$idx_dso_scheme-1] =~ /^(dl|dlfcn|win32|vms)$/)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										27
									
								
								FAQ
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								FAQ
									
									
									
									
									
								
							@@ -70,7 +70,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 0.9.7e was released on October 25, 2004.
 | 
					OpenSSL 0.9.7g was released on April 11, 2005.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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:
 | 
				
			||||||
@@ -141,8 +141,8 @@ less Unix-centric, it might have been used much earlier.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
With version 0.9.6 OpenSSL was extended to interface to external crypto
 | 
					With version 0.9.6 OpenSSL was extended to interface to external crypto
 | 
				
			||||||
hardware. This was realized in a special release '0.9.6-engine'. With
 | 
					hardware. This was realized in a special release '0.9.6-engine'. With
 | 
				
			||||||
version 0.9.7 (not yet released) the changes were merged into the main
 | 
					version 0.9.7 the changes were merged into the main development line,
 | 
				
			||||||
development line, so that the special release is no longer necessary.
 | 
					so that the special release is no longer necessary.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* How do I check the authenticity of the OpenSSL distribution?
 | 
					* How do I check the authenticity of the OpenSSL distribution?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -472,6 +472,10 @@ This will only compile sha_dgst.c with -O0, the rest with the optimization
 | 
				
			|||||||
level chosen by the configuration process.  When the above is done, do the
 | 
					level chosen by the configuration process.  When the above is done, do the
 | 
				
			||||||
test and installation and you're set.
 | 
					test and installation and you're set.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					3. Reconfigure the toolkit with no-sha0 option to leave out SHA0. It
 | 
				
			||||||
 | 
					should not be used and is not used in SSL/TLS nor any other recognized
 | 
				
			||||||
 | 
					protocol in either case.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Why does the OpenSSL compilation fail with "ar: command not found"?
 | 
					* Why does the OpenSSL compilation fail with "ar: command not found"?
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -788,9 +792,20 @@ that is allocated when an application starts up. Since such tables do not grow
 | 
				
			|||||||
in size over time they are harmless.
 | 
					in size over time they are harmless.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
These internal tables can be freed up when an application closes using various
 | 
					These internal tables can be freed up when an application closes using various
 | 
				
			||||||
functions.  Currently these include: EVP_cleanup(), ERR_remove_state(),
 | 
					functions.  Currently these include following:
 | 
				
			||||||
ERR_free_strings(), ENGINE_cleanup(), CONF_modules_unload() and
 | 
					
 | 
				
			||||||
CRYPTO_cleanup_all_ex_data().
 | 
					Thread-local cleanup functions:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  ERR_remove_state()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Application-global cleanup functions that are aware of usage (and therefore
 | 
				
			||||||
 | 
					thread-safe):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  ENGINE_cleanup() and CONF_modules_unload()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					"Brutal" (thread-unsafe) Application-global cleanup functions:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  ERR_free_strings(), EVP_cleanup() and CRYPTO_cleanup_all_ex_data().
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
===============================================================================
 | 
					===============================================================================
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,32 +3,45 @@
 | 
				
			|||||||
 INSTALLATION ON THE DOS PLATFORM WITH DJGPP
 | 
					 INSTALLATION ON THE DOS PLATFORM WITH DJGPP
 | 
				
			||||||
 -------------------------------------------
 | 
					 -------------------------------------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Openssl has been ported to DOS, but only with long filename support. If
 | 
					 OpenSSL has been ported to DJGPP, a Unix look-alike 32-bit run-time
 | 
				
			||||||
 you wish to compile on native DOS with 8+3 filenames, you will have to
 | 
					 environment for 16-bit DOS, but only with long filename support.
 | 
				
			||||||
 tweak the installation yourself, including renaming files with illegal
 | 
					 If you wish to compile on native DOS with 8+3 filenames, you will
 | 
				
			||||||
 or duplicate names.
 | 
					 have to tweak the installation yourself, including renaming files
 | 
				
			||||||
 | 
					 with illegal or duplicate names.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 You should have a full DJGPP environment installed, including the
 | 
					 You should have a full DJGPP environment installed, including the
 | 
				
			||||||
 latest versions of DJGPP, GCC, BINUTILS, BASH, etc. This package
 | 
					 latest versions of DJGPP, GCC, BINUTILS, BASH, etc. This package
 | 
				
			||||||
 requires that PERL and BC also be installed.
 | 
					 requires that PERL and BC also be installed.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 All of these can be obtained from the usual DJGPP mirror sites, such
 | 
					 All of these can be obtained from the usual DJGPP mirror sites or
 | 
				
			||||||
 as "ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp". You also need to
 | 
					 directly at "http://www.delorie.com/pub/djgpp". For help on which
 | 
				
			||||||
 have the WATT-32 networking package installed before you try to compile
 | 
					 files to download, see the DJGPP "ZIP PICKER" page at
 | 
				
			||||||
 openssl. This can be obtained from "http://www.bgnett.no/~giva/".
 | 
					 "http://www.delorie.com/djgpp/zip-picker.html". You also need to have
 | 
				
			||||||
 | 
					 the WATT-32 networking package installed before you try to compile
 | 
				
			||||||
 | 
					 OpenSSL. This can be obtained from "http://www.bgnett.no/~giva/".
 | 
				
			||||||
 The Makefile assumes that the WATT-32 code is in the directory
 | 
					 The Makefile assumes that the WATT-32 code is in the directory
 | 
				
			||||||
 specified by the environment variable WATT_ROOT. If you have watt-32
 | 
					 specified by the environment variable WATT_ROOT. If you have watt-32
 | 
				
			||||||
 in directory "watt32" under your main DJGPP directory, specify
 | 
					 in directory "watt32" under your main DJGPP directory, specify
 | 
				
			||||||
 WATT_ROOT="/dev/env/DJDIR/watt32".
 | 
					 WATT_ROOT="/dev/env/DJDIR/watt32".
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 To compile openssl, start your BASH shell. Then configure for DOS by
 | 
					 To compile OpenSSL, start your BASH shell, then configure for DJGPP by
 | 
				
			||||||
 running "./Configure" with appropriate arguments. The basic syntax for
 | 
					 running "./Configure" with appropriate arguments:
 | 
				
			||||||
 DOS is:
 | 
					 | 
				
			||||||
 ./Configure no-threads --prefix=/dev/env/DJDIR DJGPP
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 You may run out of DPMI selectors when running in a DOS box under
 | 
						./Configure no-threads --prefix=/dev/env/DJDIR DJGPP
 | 
				
			||||||
 Windows. If so, just close the BASH shell, go back to Windows, and
 | 
					 | 
				
			||||||
 restart BASH. Then run "make" again.
 | 
					 | 
				
			||||||
 
 | 
					 
 | 
				
			||||||
 Building openssl under DJGPP has been tested with DJGPP 2.03,
 | 
					 And finally fire up "make". You may run out of DPMI selectors when
 | 
				
			||||||
 GCC 2.952, GCC 2.953, perl 5.005_02 and perl 5.006_01.
 | 
					 running in a DOS box under Windows. If so, just close the BASH
 | 
				
			||||||
 | 
					 shell, go back to Windows, and restart BASH. Then run "make" again.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 RUN-TIME CAVEAT LECTOR
 | 
				
			||||||
 | 
					 --------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 Quoting FAQ:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  "Cryptographic software needs a source of unpredictable data to work
 | 
				
			||||||
 | 
					   correctly.  Many open source operating systems provide a "randomness
 | 
				
			||||||
 | 
					   device" (/dev/urandom or /dev/random) that serves this purpose."
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 As of version 0.9.7f DJGPP port checks upon /dev/urandom$ for a 3rd
 | 
				
			||||||
 | 
					 party "randomness" DOS driver. One such driver, NOISE.SYS, can be
 | 
				
			||||||
 | 
					 obtained from "http://www.rahul.net/dkaufman/index.html".
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							@@ -12,7 +12,7 @@
 | 
				
			|||||||
  ---------------
 | 
					  ---------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 1998-2004 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1998-2005 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
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										150
									
								
								Makefile.org
									
									
									
									
									
								
							
							
						
						
									
										150
									
								
								Makefile.org
									
									
									
									
									
								
							@@ -102,6 +102,7 @@ PROCESSOR=
 | 
				
			|||||||
# Set DES_ENC to des_enc.o if you want to use the C version
 | 
					# Set DES_ENC to des_enc.o if you want to use the C version
 | 
				
			||||||
#There are 4 x86 assember options.
 | 
					#There are 4 x86 assember options.
 | 
				
			||||||
FIPS_DES_ENC= des_enc.o fcrypt_b.o
 | 
					FIPS_DES_ENC= des_enc.o fcrypt_b.o
 | 
				
			||||||
 | 
					FIPS_AES_ENC= fips_aes_core.o
 | 
				
			||||||
DES_ENC= asm/dx86-out.o asm/yx86-out.o
 | 
					DES_ENC= asm/dx86-out.o asm/yx86-out.o
 | 
				
			||||||
#DES_ENC= des_enc.o fcrypt_b.o          # C
 | 
					#DES_ENC= des_enc.o fcrypt_b.o          # C
 | 
				
			||||||
#DES_ENC= asm/dx86-elf.o asm/yx86-elf.o # elf
 | 
					#DES_ENC= asm/dx86-elf.o asm/yx86-elf.o # elf
 | 
				
			||||||
@@ -176,7 +177,7 @@ LIBKRB5=
 | 
				
			|||||||
SHLIB_MARK=
 | 
					SHLIB_MARK=
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DIRS=   crypto fips ssl $(SHLIB_MARK) sigs apps test tools
 | 
					DIRS=   crypto fips ssl $(SHLIB_MARK) sigs apps test tools
 | 
				
			||||||
SHLIBDIRS= fips crypto ssl
 | 
					SHLIBDIRS= crypto ssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# dirs in crypto to build
 | 
					# dirs in crypto to build
 | 
				
			||||||
SDIRS=  objects \
 | 
					SDIRS=  objects \
 | 
				
			||||||
@@ -186,7 +187,7 @@ SDIRS=  objects \
 | 
				
			|||||||
	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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
FDIRS=	sha1 rand des aes dsa rsa dh
 | 
					FDIRS=	sha rand des aes dsa rsa dh hmac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# tests to perform.  "alltests" is a special word indicating that all tests
 | 
					# tests to perform.  "alltests" is a special word indicating that all tests
 | 
				
			||||||
# should be performed.
 | 
					# should be performed.
 | 
				
			||||||
@@ -227,9 +228,9 @@ all: Makefile sub_all openssl.pc
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
sigs:	$(SIGS)
 | 
					sigs:	$(SIGS)
 | 
				
			||||||
libcrypto.a.sha1: libcrypto.a
 | 
					libcrypto.a.sha1: libcrypto.a
 | 
				
			||||||
	if egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null; then \
 | 
						@if egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null; then \
 | 
				
			||||||
		$(RANLIB) libcrypto.a; \
 | 
							$(RANLIB) libcrypto.a; \
 | 
				
			||||||
		fips/sha1/fips_standalone_sha1 libcrypto.a > libcrypto.a.sha1; \
 | 
							fips/sha/fips_standalone_sha1 libcrypto.a > libcrypto.a.sha1; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
sub_all:
 | 
					sub_all:
 | 
				
			||||||
@@ -237,7 +238,7 @@ sub_all:
 | 
				
			|||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making all in $$i..." && \
 | 
							(cd $$i && echo "making all in $$i..." && \
 | 
				
			||||||
		$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAG='${ASFLAG}' SDIRS='$(SDIRS)' FDIRS='$(FDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' all ) || exit 1; \
 | 
							$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAG='${ASFLAG}' SDIRS='$(SDIRS)' FDIRS='$(FDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' FIPS_AES_ENC='${FIPS_AES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' all ) || exit 1; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		$(MAKE) $$i; \
 | 
							$(MAKE) $$i; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
@@ -248,7 +249,7 @@ sub_target:
 | 
				
			|||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making $(TARGET) in $$i..." && \
 | 
							(cd $$i && echo "making $(TARGET) in $$i..." && \
 | 
				
			||||||
		$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAG='${ASFLAG}' SDIRS='$(SDIRS)' FDIRS='$(FDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TARGET='$(TARGET)' sub_target ) || exit 1; \
 | 
							$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' AS='${AS}' ASFLAG='${ASFLAG}' SDIRS='$(SDIRS)' FDIRS='$(FDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' FIPS_AES_ENC='${FIPS_AES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TARGET='$(TARGET)' sub_target ) || exit 1; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
		$(MAKE) $$i; \
 | 
							$(MAKE) $$i; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
@@ -257,6 +258,9 @@ sub_target:
 | 
				
			|||||||
libcrypto$(SHLIB_EXT): libcrypto.a
 | 
					libcrypto$(SHLIB_EXT): libcrypto.a
 | 
				
			||||||
	@if [ "$(SHLIB_TARGET)" != "" ]; then \
 | 
						@if [ "$(SHLIB_TARGET)" != "" ]; then \
 | 
				
			||||||
		$(MAKE) SHLIBDIRS=crypto build-shared; \
 | 
							$(MAKE) SHLIBDIRS=crypto build-shared; \
 | 
				
			||||||
 | 
					        	if egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null; then \
 | 
				
			||||||
 | 
					                    fips/sha/fips_standalone_sha1 -binary $@ > $@.$${HMAC_EXT:-sha1}; \
 | 
				
			||||||
 | 
							fi; \
 | 
				
			||||||
	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; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
@@ -309,7 +313,7 @@ do_gnu-shared:
 | 
				
			|||||||
		-Wl,-soname=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
							-Wl,-soname=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		-Wl,-Bsymbolic \
 | 
							-Wl,-Bsymbolic \
 | 
				
			||||||
		-Wl,--whole-archive lib$$i.a \
 | 
							-Wl,--whole-archive lib$$i.a \
 | 
				
			||||||
		-Wl,--no-whole-archive $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
							-Wl,--no-whole-archive $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
	libs="-l$$i $$libs"; \
 | 
						libs="-l$$i $$libs"; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -321,7 +325,8 @@ do_darwin-shared:
 | 
				
			|||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
							libs="$(LIBKRB5) $$libs"; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	( set -x; ${CC} --verbose -dynamiclib -o lib$$i${SHLIB_EXT} \
 | 
						( set -x; ${CC} ${SHARED_LDFLAGS}
 | 
				
			||||||
 | 
							--verbose -dynamiclib -o lib$$i${SHLIB_EXT} \
 | 
				
			||||||
		lib$$i.a $$libs -all_load -current_version ${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
							lib$$i.a $$libs -all_load -current_version ${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
		-compatibility_version ${SHLIB_MAJOR}.`echo ${SHLIB_MINOR} | cut -d. -f1` \
 | 
							-compatibility_version ${SHLIB_MAJOR}.`echo ${SHLIB_MINOR} | cut -d. -f1` \
 | 
				
			||||||
		-install_name ${INSTALLTOP}/lib/lib$$i${SHLIB_EXT} ) || exit 1; \
 | 
							-install_name ${INSTALLTOP}/lib/lib$$i${SHLIB_EXT} ) || exit 1; \
 | 
				
			||||||
@@ -334,11 +339,18 @@ do_cygwin-shared:
 | 
				
			|||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
							libs="$(LIBKRB5) $$libs"; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	( set -x; ${CC}  -shared -o cyg$$i-$(SHLIB_VERSION_NUMBER).dll \
 | 
						shlib=cyg$${i}-$(SHLIB_VERSION_NUMBER).dll; \
 | 
				
			||||||
 | 
						[ "$(PLATFORM)" = "mingw" ] && shlib=$${i}eay32.dll; \
 | 
				
			||||||
 | 
						[ -f apps/$$shlib ] && rm apps/$$shlib; \
 | 
				
			||||||
 | 
						[ -f test/$$shlib ] && rm test/$$shlib; \
 | 
				
			||||||
 | 
						base=;  [ $$i = "crypto" ] && base=-Wl,--image-base,0x63000000; \
 | 
				
			||||||
 | 
						( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
 | 
							-shared $$base -o $$shlib \
 | 
				
			||||||
		-Wl,-Bsymbolic \
 | 
							-Wl,-Bsymbolic \
 | 
				
			||||||
		-Wl,--whole-archive lib$$i.a \
 | 
							-Wl,--whole-archive lib$$i.a \
 | 
				
			||||||
		-Wl,--out-implib,lib$$i.dll.a \
 | 
							-Wl,--out-implib,lib$$i.dll.a \
 | 
				
			||||||
		-Wl,--no-whole-archive $$libs ) || exit 1; \
 | 
							-Wl,--no-whole-archive $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
 | 
						cp -p $$shlib apps/; cp -p $$shlib test/; \
 | 
				
			||||||
	libs="-l$$i $$libs"; \
 | 
						libs="-l$$i $$libs"; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -354,7 +366,7 @@ do_alpha-osf1-shared:
 | 
				
			|||||||
		( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
							( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			-shared -o lib$$i.so \
 | 
								-shared -o lib$$i.so \
 | 
				
			||||||
			-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
								-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
				
			||||||
			-all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
								-all lib$$i.a -none $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="-l$$i $$libs"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
@@ -373,7 +385,7 @@ do_tru64-shared:
 | 
				
			|||||||
		( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
							( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			-shared -msym -o lib$$i.so \
 | 
								-shared -msym -o lib$$i.so \
 | 
				
			||||||
			-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
								-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
				
			||||||
			-all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
								-all lib$$i.a -none $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="-l$$i $$libs"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
@@ -393,7 +405,7 @@ do_tru64-shared-rpath:
 | 
				
			|||||||
			-shared -msym -o lib$$i.so \
 | 
								-shared -msym -o lib$$i.so \
 | 
				
			||||||
			-rpath  ${INSTALLTOP}/lib \
 | 
								-rpath  ${INSTALLTOP}/lib \
 | 
				
			||||||
			-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
								-set_version "${SHLIB_VERSION_HISTORY}${SHLIB_VERSION_NUMBER}" \
 | 
				
			||||||
			-all lib$$i.a -none $$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
								-all lib$$i.a -none $$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="-l$$i $$libs"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
@@ -411,12 +423,12 @@ do_solaris-shared:
 | 
				
			|||||||
		( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
							( PATH=/usr/ccs/bin:$$PATH ; export PATH; \
 | 
				
			||||||
		  MINUSZ='-z '; \
 | 
							  MINUSZ='-z '; \
 | 
				
			||||||
		  (${CC} -v 2>&1 | grep gcc) > /dev/null && MINUSZ='-Wl,-z,'; \
 | 
							  (${CC} -v 2>&1 | grep gcc) > /dev/null && MINUSZ='-Wl,-z,'; \
 | 
				
			||||||
		  set -x; ${CC} ${SHARED_LDFLAGS} -G -dy -z text \
 | 
							  set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			-o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-h lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			-Wl,-Bsymbolic \
 | 
								-Wl,-Bsymbolic \
 | 
				
			||||||
			$${MINUSZ}allextract lib$$i.a $${MINUSZ}defaultextract \
 | 
								$${MINUSZ}allextract lib$$i.a $${MINUSZ}defaultextract \
 | 
				
			||||||
			$$libs ${EX_LIBS} -lc ) || exit 1; \
 | 
								$$libs ${EX_LIBS} ) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="-l$$i $$libs"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
@@ -479,61 +491,35 @@ do_irix-shared:
 | 
				
			|||||||
		if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
							if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
				
			||||||
			libs="$(LIBKRB5) $$libs"; \
 | 
								libs="$(LIBKRB5) $$libs"; \
 | 
				
			||||||
		fi; \
 | 
							fi; \
 | 
				
			||||||
		( WHOLELIB="-all lib$$i.a -notall"; \
 | 
							( WHOLELIB="-all lib$$i.a -none"; \
 | 
				
			||||||
		  (${CC} -v 2>&1 | grep gcc) > /dev/null && WHOLELIB="-Wl,-all,lib$$i.a,-notall"; \
 | 
							  (${CC} -v 2>&1 | grep gcc) > /dev/null && WHOLELIB="-Wl,-all,lib$$i.a,-none"; \
 | 
				
			||||||
		  set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
							  set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
			-shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-shared -o lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			-Wl,-soname,lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
								-Wl,-soname,lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
				
			||||||
			$${WHOLELIB} $$libs ${EX_LIBS} -lc) || exit 1; \
 | 
								$${WHOLELIB} $$libs ${EX_LIBS}) || exit 1; \
 | 
				
			||||||
		libs="-l$$i $$libs"; \
 | 
							libs="-l$$i $$libs"; \
 | 
				
			||||||
		done; \
 | 
							done; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# This assumes that GNU utilities are *not* used
 | 
					# This assumes that GNU utilities are *not* used
 | 
				
			||||||
# HP-UX includes the full pathname of libs we depend on, so we would get
 | 
					 | 
				
			||||||
# ./libcrypto (with ./ as path information) compiled into libssl, hence
 | 
					 | 
				
			||||||
# we omit the SHLIBDEPS. Applications must be linked with -lssl -lcrypto
 | 
					 | 
				
			||||||
# anyway.
 | 
					 | 
				
			||||||
# The object modules are loaded from lib$i.a using the undocumented -Fl
 | 
					 | 
				
			||||||
# option.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# WARNING: Until DSO is fixed to support a search path, we support SHLIB_PATH
 | 
					 | 
				
			||||||
#          by temporarily specifying "+s"!
 | 
					 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
do_hpux-shared:
 | 
					do_hpux-shared:
 | 
				
			||||||
	for i in ${SHLIBDIRS}; do \
 | 
						for i in ${SHLIBDIRS}; do \
 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
						if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
							libs="$(LIBKRB5) $$libs"; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	( set -x; /usr/ccs/bin/ld ${SHARED_LDFLAGS} \
 | 
						if expr $(PLATFORM) : '.*ia64' > /dev/null; then \
 | 
				
			||||||
		+vnocompatwarnings \
 | 
							shlib=lib$$i.so.${SHLIB_MAJOR}.${SHLIB_MINOR}; \
 | 
				
			||||||
		-b -z +s \
 | 
						else \
 | 
				
			||||||
		-o lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
							shlib=lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR}; \
 | 
				
			||||||
		+h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
					 | 
				
			||||||
		-Fl lib$$i.a -ldld -lc ) || exit 1; \
 | 
					 | 
				
			||||||
	chmod a=rx lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR}; \
 | 
					 | 
				
			||||||
	done
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# This assumes that GNU utilities are *not* used
 | 
					 | 
				
			||||||
# HP-UX includes the full pathname of libs we depend on, so we would get
 | 
					 | 
				
			||||||
# ./libcrypto (with ./ as path information) compiled into libssl, hence
 | 
					 | 
				
			||||||
# we omit the SHLIBDEPS. Applications must be linked with -lssl -lcrypto
 | 
					 | 
				
			||||||
# anyway.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# HP-UX in 64bit mode has "+s" enabled by default; it will search for
 | 
					 | 
				
			||||||
# shared libraries along LD_LIBRARY_PATH _and_ SHLIB_PATH.
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
do_hpux64-shared:
 | 
					 | 
				
			||||||
	for i in ${SHLIBDIRS}; do \
 | 
					 | 
				
			||||||
	if [ "${SHLIBDIRS}" = "ssl" -a -n "$(LIBKRB5)" ]; then \
 | 
					 | 
				
			||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
					 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	( set -x; /usr/ccs/bin/ld ${SHARED_LDFLAGS} \
 | 
						[ -f $$shlib ] && rm -f $$shlib; \
 | 
				
			||||||
		-b -z \
 | 
						ALLSYMSFLAGS='-Wl,-Fl'; \
 | 
				
			||||||
		-o lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
						expr $(PLATFORM) : 'hpux64' > /dev/null && ALLSYMSFLAGS='-Wl,+forceload'; \
 | 
				
			||||||
		+h lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR} \
 | 
						( set -x; ${CC} ${SHARED_LDFLAGS} \
 | 
				
			||||||
		+forceload lib$$i.a -ldl -lc ) || exit 1; \
 | 
							-Wl,-B,symbolic,+vnocompatwarnings,-z,+h,$$shlib \
 | 
				
			||||||
	chmod a=rx lib$$i.sl.${SHLIB_MAJOR}.${SHLIB_MINOR}; \
 | 
							-o $$shlib $$ALLSYMSFLAGS,lib$$i.a -ldld ) || exit 1; \
 | 
				
			||||||
 | 
						chmod a=rx $$shlib; \
 | 
				
			||||||
	done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# The following method is said to work on all platforms.  Tests will
 | 
					# The following method is said to work on all platforms.  Tests will
 | 
				
			||||||
@@ -574,6 +560,8 @@ do_aix-shared:
 | 
				
			|||||||
		libs="$(LIBKRB5) $$libs"; \
 | 
							libs="$(LIBKRB5) $$libs"; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	( set -x; \
 | 
						( set -x; \
 | 
				
			||||||
 | 
						  OBJECT_MODE=`expr x${SHARED_LDFLAGS} : 'x\-[a-z]\([0-9]*\)'`; \
 | 
				
			||||||
 | 
						  OBJECT_MODE=$${OBJECT_MODE:-32}; export OBJECT_MODE; \
 | 
				
			||||||
	  ld -r -o lib$$i.o $(ALLSYMSFLAG) lib$$i.a && \
 | 
						  ld -r -o lib$$i.o $(ALLSYMSFLAG) lib$$i.a && \
 | 
				
			||||||
	  ( nm -Pg lib$$i.o | grep ' [BD] ' | cut -f1 -d' ' > lib$$i.exp; \
 | 
						  ( nm -Pg lib$$i.o | grep ' [BD] ' | cut -f1 -d' ' > lib$$i.exp; \
 | 
				
			||||||
	    $(SHAREDCMD) $(SHAREDFLAGS) \
 | 
						    $(SHAREDCMD) $(SHAREDFLAGS) \
 | 
				
			||||||
@@ -627,7 +615,7 @@ clean:	libclean
 | 
				
			|||||||
	do \
 | 
						do \
 | 
				
			||||||
	if [ -d "$$i" ]; then \
 | 
						if [ -d "$$i" ]; then \
 | 
				
			||||||
		(cd $$i && echo "making clean in $$i..." && \
 | 
							(cd $$i && echo "making clean in $$i..." && \
 | 
				
			||||||
		$(MAKE) SDIRS='${SDIRS}' clean ) || exit 1; \
 | 
							$(MAKE) EXE_EXT='${EXE_EXT}' SDIRS='${SDIRS}' clean ) || exit 1; \
 | 
				
			||||||
		rm -f $(LIBS); \
 | 
							rm -f $(LIBS); \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	done;
 | 
						done;
 | 
				
			||||||
@@ -679,15 +667,10 @@ dclean:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
rehash: rehash.time
 | 
					rehash: rehash.time
 | 
				
			||||||
rehash.time: certs
 | 
					rehash.time: certs
 | 
				
			||||||
	@(OPENSSL="`pwd`/apps/openssl$(EXE_EXT)"; OPENSSL_DEBUG_MEMORY=on; \
 | 
						@(OPENSSL="`pwd`/util/opensslwrap.sh"; \
 | 
				
			||||||
		export OPENSSL OPENSSL_DEBUG_MEMORY; \
 | 
						  OPENSSL_DEBUG_MEMORY=on; \
 | 
				
			||||||
		LD_LIBRARY_PATH="`pwd`:$$LD_LIBRARY_PATH"; \
 | 
						  export OPENSSL OPENSSL_DEBUG_MEMORY; \
 | 
				
			||||||
		DYLD_LIBRARY_PATH="`pwd`:$$DYLD_LIBRARY_PATH"; \
 | 
						  $(PERL) tools/c_rehash certs)
 | 
				
			||||||
		SHLIB_PATH="`pwd`:$$SHLIB_PATH"; \
 | 
					 | 
				
			||||||
		LIBPATH="`pwd`:$$LIBPATH"; \
 | 
					 | 
				
			||||||
		if [ "$(PLATFORM)" = "Cygwin" ]; then PATH="`pwd`:$$PATH"; fi; \
 | 
					 | 
				
			||||||
		export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; \
 | 
					 | 
				
			||||||
		$(PERL) tools/c_rehash certs)
 | 
					 | 
				
			||||||
	touch rehash.time
 | 
						touch rehash.time
 | 
				
			||||||
 | 
					
 | 
				
			||||||
test:   tests
 | 
					test:   tests
 | 
				
			||||||
@@ -695,13 +678,7 @@ test:   tests
 | 
				
			|||||||
tests: rehash
 | 
					tests: rehash
 | 
				
			||||||
	@(cd test && echo "testing..." && \
 | 
						@(cd test && echo "testing..." && \
 | 
				
			||||||
	$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TESTS='${TESTS}' OPENSSL_DEBUG_MEMORY=on tests );
 | 
						$(MAKE) CC='${CC}' PLATFORM='${PLATFORM}' CFLAG='${CFLAG}' SDIRS='$(SDIRS)' INSTALLTOP='${INSTALLTOP}' PEX_LIBS='${PEX_LIBS}' EX_LIBS='${EX_LIBS}' BN_ASM='${BN_ASM}' DES_ENC='${DES_ENC}' FIPS_DES_ENC='${FIPS_DES_ENC}' BF_ENC='${BF_ENC}' CAST_ENC='${CAST_ENC}' RC4_ENC='${RC4_ENC}' RC5_ENC='${RC5_ENC}' SHA1_ASM_OBJ='${SHA1_ASM_OBJ}' FIPS_SHA1_ASM_OBJ='${FIPS_SHA1_ASM_OBJ}' MD5_ASM_OBJ='${MD5_ASM_OBJ}' RMD160_ASM_OBJ='${RMD160_ASM_OBJ}' AR='${AR}' PROCESSOR='${PROCESSOR}' PERL='${PERL}' RANLIB='${RANLIB}' TESTS='${TESTS}' KRB5_INCLUDES='${KRB5_INCLUDES}' LIBKRB5='${LIBKRB5}' EXE_EXT='${EXE_EXT}' SHARED_LIBS='${SHARED_LIBS}' SHLIB_EXT='${SHLIB_EXT}' SHLIB_TARGET='${SHLIB_TARGET}' TESTS='${TESTS}' OPENSSL_DEBUG_MEMORY=on tests );
 | 
				
			||||||
	@LD_LIBRARY_PATH="`pwd`:$$LD_LIBRARY_PATH"; \
 | 
						util/shlib_wrap.sh apps/openssl version -a
 | 
				
			||||||
	DYLD_LIBRARY_PATH="`pwd`:$$DYLD_LIBRARY_PATH"; \
 | 
					 | 
				
			||||||
	SHLIB_PATH="`pwd`:$$SHLIB_PATH"; \
 | 
					 | 
				
			||||||
	LIBPATH="`pwd`:$$LIBPATH"; \
 | 
					 | 
				
			||||||
	if [ "$(PLATFORM)" = "Cygwin" ]; then PATH="`pwd`:$$PATH"; fi; \
 | 
					 | 
				
			||||||
	export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; \
 | 
					 | 
				
			||||||
	apps/openssl version -a
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
report:
 | 
					report:
 | 
				
			||||||
	@$(PERL) util/selftest.pl
 | 
						@$(PERL) util/selftest.pl
 | 
				
			||||||
@@ -749,11 +726,15 @@ crypto/objects/obj_mac.h: crypto/objects/objects.pl crypto/objects/objects.txt c
 | 
				
			|||||||
apps/openssl-vms.cnf: apps/openssl.cnf
 | 
					apps/openssl-vms.cnf: apps/openssl.cnf
 | 
				
			||||||
	$(PERL) VMS/VMSify-conf.pl < apps/openssl.cnf > apps/openssl-vms.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
 | 
					TABLE: Configure
 | 
				
			||||||
	(echo 'Output of `Configure TABLE'"':"; \
 | 
						(echo 'Output of `Configure TABLE'"':"; \
 | 
				
			||||||
	$(PERL) Configure TABLE) > TABLE
 | 
						$(PERL) Configure TABLE) > TABLE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
update: depend errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.h apps/openssl-vms.cnf TABLE
 | 
					update: errors stacks util/libeay.num util/ssleay.num crypto/objects/obj_dat.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
 | 
					# 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
 | 
					# pretty long, on several platforms a "too many arguments" error or similar
 | 
				
			||||||
@@ -800,7 +781,7 @@ install_sw:
 | 
				
			|||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/misc \
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/misc \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/certs \
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/certs \
 | 
				
			||||||
		$(INSTALL_PREFIX)$(OPENSSLDIR)/private
 | 
							$(INSTALL_PREFIX)$(OPENSSLDIR)/private
 | 
				
			||||||
	@for i in $(EXHEADER) ;\
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
@@ -835,7 +816,16 @@ install_sw:
 | 
				
			|||||||
				if [ "$(PLATFORM)" != "Cygwin" ]; then \
 | 
									if [ "$(PLATFORM)" != "Cygwin" ]; then \
 | 
				
			||||||
					cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
										cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
					chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
										chmod 555 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new; \
 | 
				
			||||||
					mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
										mv -f	$(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i.new \
 | 
				
			||||||
 | 
											$(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$i; \
 | 
				
			||||||
 | 
										sig="$$i.$${HMAC_EXT:-sha1}"; \
 | 
				
			||||||
 | 
										if [ -f $$sig ]; then \
 | 
				
			||||||
 | 
											echo installing $$sig; \
 | 
				
			||||||
 | 
											cp $$sig $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$sig.new; \
 | 
				
			||||||
 | 
											chmod 444 $(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$sig.new; \
 | 
				
			||||||
 | 
											mv -f	$(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$sig.new \
 | 
				
			||||||
 | 
												$(INSTALL_PREFIX)$(INSTALLTOP)/lib/$$sig; \
 | 
				
			||||||
 | 
										fi; \
 | 
				
			||||||
				else \
 | 
									else \
 | 
				
			||||||
					c=`echo $$i | sed 's/^lib\(.*\)\.dll/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \
 | 
										c=`echo $$i | sed 's/^lib\(.*\)\.dll/cyg\1-$(SHLIB_VERSION_NUMBER).dll/'`; \
 | 
				
			||||||
					cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
										cp $$c $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$c.new; \
 | 
				
			||||||
@@ -879,7 +869,7 @@ install_docs:
 | 
				
			|||||||
	@pod2man="`cd util; ./pod2mantest $(PERL)`"; \
 | 
						@pod2man="`cd util; ./pod2mantest $(PERL)`"; \
 | 
				
			||||||
	here="`pwd`"; \
 | 
						here="`pwd`"; \
 | 
				
			||||||
	filecase=; \
 | 
						filecase=; \
 | 
				
			||||||
	if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" ]; then \
 | 
						if [ "$(PLATFORM)" = "DJGPP" -o "$(PLATFORM)" = "Cygwin" -o "$(PLATFORM)" = "mingw" ]; then \
 | 
				
			||||||
		filecase=-i; \
 | 
							filecase=-i; \
 | 
				
			||||||
	fi; \
 | 
						fi; \
 | 
				
			||||||
	for i in doc/apps/*.pod; do \
 | 
						for i in doc/apps/*.pod; do \
 | 
				
			||||||
@@ -892,8 +882,8 @@ install_docs:
 | 
				
			|||||||
			--release=$(VERSION) `basename $$i`") \
 | 
								--release=$(VERSION) `basename $$i`") \
 | 
				
			||||||
			>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \
 | 
								>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \
 | 
				
			||||||
		$(PERL) util/extract-names.pl < $$i | \
 | 
							$(PERL) util/extract-names.pl < $$i | \
 | 
				
			||||||
			grep -v $$filecase "^$$fn\$$" | \
 | 
								(grep -v $$filecase "^$$fn\$$"; true) | \
 | 
				
			||||||
			grep -v "[	]" | \
 | 
								(grep -v "[	]"; true) | \
 | 
				
			||||||
			(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
								(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
				
			||||||
			 while read n; do \
 | 
								 while read n; do \
 | 
				
			||||||
				$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
									$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
				
			||||||
@@ -909,8 +899,8 @@ install_docs:
 | 
				
			|||||||
			--release=$(VERSION) `basename $$i`") \
 | 
								--release=$(VERSION) `basename $$i`") \
 | 
				
			||||||
			>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \
 | 
								>  $(INSTALL_PREFIX)$(MANDIR)/man$$sec/$$fn.$${sec}$(MANSUFFIX); \
 | 
				
			||||||
		$(PERL) util/extract-names.pl < $$i | \
 | 
							$(PERL) util/extract-names.pl < $$i | \
 | 
				
			||||||
			grep -v $$filecase "^$$fn\$$" | \
 | 
								(grep -v $$filecase "^$$fn\$$"; true) | \
 | 
				
			||||||
			grep -v "[	]" | \
 | 
								(grep -v "[	]"; true) | \
 | 
				
			||||||
			(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
								(cd $(INSTALL_PREFIX)$(MANDIR)/man$$sec/; \
 | 
				
			||||||
			 while read n; do \
 | 
								 while read n; do \
 | 
				
			||||||
				$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
									$$here/util/point.sh $$fn.$${sec}$(MANSUFFIX) "$$n".$${sec}$(MANSUFFIX); \
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										17
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								NEWS
									
									
									
									
									
								
							@@ -5,6 +5,23 @@
 | 
				
			|||||||
  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 0.9.7f and OpenSSL 0.9.7g:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      o More compilation issues fixed.
 | 
				
			||||||
 | 
					      o Adaptation to more modern Kerberos API.
 | 
				
			||||||
 | 
					      o Enhanced or corrected configuration for Solaris64, Mingw and Cygwin.
 | 
				
			||||||
 | 
					      o Enhanced x86_64 assembler BIGNUM module.
 | 
				
			||||||
 | 
					      o More constification.
 | 
				
			||||||
 | 
					      o Added processing of proxy certificates (RFC 3820).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  Major changes between OpenSSL 0.9.7e and OpenSSL 0.9.7f:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      o Several compilation issues fixed.
 | 
				
			||||||
 | 
					      o Many memory allocation failure checks added.
 | 
				
			||||||
 | 
					      o Improved comparison of X509 Name type.
 | 
				
			||||||
 | 
					      o Mandatory basic checks on certificates.
 | 
				
			||||||
 | 
					      o Performance improvements.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  Major changes between OpenSSL 0.9.7d and OpenSSL 0.9.7e:
 | 
					  Major changes between OpenSSL 0.9.7d and OpenSSL 0.9.7e:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      o Fix race condition in CRL checking code.
 | 
					      o Fix race condition in CRL checking code.
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										65
									
								
								PROBLEMS
									
									
									
									
									
								
							
							
						
						
									
										65
									
								
								PROBLEMS
									
									
									
									
									
								
							@@ -48,20 +48,28 @@ will interfere with each other and lead to test failure.
 | 
				
			|||||||
The solution is simple for now: don't run parallell make when testing.
 | 
					The solution is simple for now: don't run parallell make when testing.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Bugs in gcc 3.0 triggered
 | 
					* Bugs in gcc triggered
 | 
				
			||||||
 | 
					
 | 
				
			||||||
According to a problem report, there are bugs in gcc 3.0 that are
 | 
					- According to a problem report, there are bugs in gcc 3.0 that are
 | 
				
			||||||
triggered by some of the code in OpenSSL, more specifically in
 | 
					  triggered by some of the code in OpenSSL, more specifically in
 | 
				
			||||||
PEM_get_EVP_CIPHER_INFO().  The triggering code is the following:
 | 
					  PEM_get_EVP_CIPHER_INFO().  The triggering code is the following:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	header+=11;
 | 
						header+=11;
 | 
				
			||||||
	if (*header != '4') return(0); header++;
 | 
						if (*header != '4') return(0); header++;
 | 
				
			||||||
	if (*header != ',') return(0); header++;
 | 
						if (*header != ',') return(0); header++;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
What happens is that gcc might optimize a little too agressively, and
 | 
					  What happens is that gcc might optimize a little too agressively, and
 | 
				
			||||||
you end up with an extra incrementation when *header != '4'.
 | 
					  you end up with an extra incrementation when *header != '4'.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
We recommend that you upgrade gcc to as high a 3.x version as you can.
 | 
					  We recommend that you upgrade gcc to as high a 3.x version as you can.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- According to multiple problem reports, some of our message digest
 | 
				
			||||||
 | 
					  implementations trigger bug[s] in code optimizer in gcc 3.3 for sparc64
 | 
				
			||||||
 | 
					  and gcc 2.96 for ppc. Former fails to complete RIPEMD160 test, while
 | 
				
			||||||
 | 
					  latter - SHA one.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  The recomendation is to upgrade your compiler. This naturally applies to
 | 
				
			||||||
 | 
					  other similar cases.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* solaris64-sparcv9-cc SHA-1 performance with WorkShop 6 compiler.
 | 
					* solaris64-sparcv9-cc SHA-1 performance with WorkShop 6 compiler.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -90,15 +98,6 @@ failures in other parts of the code.
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
Workaround: modify the target to +O2 when building with no-asm.
 | 
					Workaround: modify the target to +O2 when building with no-asm.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
* Poor support for AIX shared builds.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
do_aix-shared rule is not flexible enough to parameterize through a
 | 
					 | 
				
			||||||
config-line. './Configure aix43-cc shared' is working, but not
 | 
					 | 
				
			||||||
'./Configure aix64-gcc shared'. In latter case make fails to create shared
 | 
					 | 
				
			||||||
libraries. It's possible to build 64-bit shared libraries by running
 | 
					 | 
				
			||||||
'env OBJECT_MODE=64 make', but we need more elegant solution. Preferably one
 | 
					 | 
				
			||||||
supporting even gcc shared builds. See RT#463 for background information.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
* Problems building shared libraries on SCO OpenServer Release 5.0.6
 | 
					* Problems building shared libraries on SCO OpenServer Release 5.0.6
 | 
				
			||||||
  with gcc 2.95.3
 | 
					  with gcc 2.95.3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -129,3 +128,37 @@ Any information helping to solve this issue would be deeply
 | 
				
			|||||||
appreciated.
 | 
					appreciated.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
NOTE: building non-shared doesn't come with this problem.
 | 
					NOTE: building non-shared doesn't come with this problem.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					* ULTRIX build fails with shell errors, such as "bad substitution"
 | 
				
			||||||
 | 
					  and "test: argument expected"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The problem is caused by ULTRIX /bin/sh supporting only original
 | 
				
			||||||
 | 
					Bourne shell syntax/semantics, and the trouble is that the vast
 | 
				
			||||||
 | 
					majority is so accustomed to more modern syntax, that very few
 | 
				
			||||||
 | 
					people [if any] would recognize the ancient syntax even as valid.
 | 
				
			||||||
 | 
					This inevitably results in non-trivial scripts breaking on ULTRIX,
 | 
				
			||||||
 | 
					and OpenSSL isn't an exclusion. Fortunately there is workaround,
 | 
				
			||||||
 | 
					hire /bin/ksh to do the job /bin/sh fails to do.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					1. Trick make(1) to use /bin/ksh by setting up following environ-
 | 
				
			||||||
 | 
					   ment variables *prior* you execute ./Configure and make:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						PROG_ENV=POSIX
 | 
				
			||||||
 | 
						MAKESHELL=/bin/ksh
 | 
				
			||||||
 | 
						export PROG_ENV MAKESHELL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   or if your shell is csh-compatible:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						setenv PROG_ENV POSIX
 | 
				
			||||||
 | 
						setenv MAKESHELL /bin/ksh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					2. Trick /bin/sh to use alternative expression evaluator. Create
 | 
				
			||||||
 | 
					   following 'test' script for example in /tmp:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#!/bin/ksh
 | 
				
			||||||
 | 
						${0##*/} "$@"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   Then 'chmod a+x /tmp/test; ln /tmp/test /tmp/[' and *prepend*
 | 
				
			||||||
 | 
					   your $PATH with chosen location, e.g. PATH=/tmp:$PATH. Alter-
 | 
				
			||||||
 | 
					   natively just replace system /bin/test and /bin/[ with the
 | 
				
			||||||
 | 
					   above script.
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										7
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								README
									
									
									
									
									
								
							@@ -1,7 +1,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 OpenSSL 0.9.7e 25 Oct 2004
 | 
					 OpenSSL 0.9.7h-dev XX xxx XXXX
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 Copyright (c) 1998-2004 The OpenSSL Project
 | 
					 Copyright (c) 1998-2005 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.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -111,6 +111,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.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 INSTALLATION
 | 
					 INSTALLATION
 | 
				
			||||||
 ------------
 | 
					 ------------
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -191,3 +193,4 @@
 | 
				
			|||||||
 # ./Configure dist; make clean
 | 
					 # ./Configure dist; make clean
 | 
				
			||||||
 # cd ..
 | 
					 # cd ..
 | 
				
			||||||
 # diff -ur openssl-orig openssl-work > mydiffs.patch
 | 
					 # diff -ur openssl-orig openssl-work > mydiffs.patch
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										5
									
								
								STATUS
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								STATUS
									
									
									
									
									
								
							@@ -1,10 +1,13 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  OpenSSL STATUS                           Last modified at
 | 
					  OpenSSL STATUS                           Last modified at
 | 
				
			||||||
  ______________                           $Date: 2004/03/17 12:01:16 $
 | 
					  ______________                           $Date: 2005/04/11 15:10:06 $
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  DEVELOPMENT STATE
 | 
					  DEVELOPMENT STATE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    o  OpenSSL 0.9.8:  Under development...
 | 
					    o  OpenSSL 0.9.8:  Under development...
 | 
				
			||||||
 | 
					    o  OpenSSL 0.9.7g: Released on April     11th, 2005
 | 
				
			||||||
 | 
					    o  OpenSSL 0.9.7f: Released on March     22nd, 2005
 | 
				
			||||||
 | 
					    o  OpenSSL 0.9.7e: Released on October   25th, 2004
 | 
				
			||||||
    o  OpenSSL 0.9.7d: Released on March     17th, 2004
 | 
					    o  OpenSSL 0.9.7d: Released on March     17th, 2004
 | 
				
			||||||
    o  OpenSSL 0.9.7c: Released on September 30th, 2003
 | 
					    o  OpenSSL 0.9.7c: Released on September 30th, 2003
 | 
				
			||||||
    o  OpenSSL 0.9.7b: Released on April     10th, 2003
 | 
					    o  OpenSSL 0.9.7b: Released on April     10th, 2003
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										366
									
								
								TABLE
									
									
									
									
									
								
							
							
						
						
									
										366
									
								
								TABLE
									
									
									
									
									
								
							@@ -92,11 +92,11 @@ $cast_obj     = asm/cx86-out.o
 | 
				
			|||||||
$rc4_obj      = asm/rx86-out.o
 | 
					$rc4_obj      = asm/rx86-out.o
 | 
				
			||||||
$rmd160_obj   = asm/rm86-out.o
 | 
					$rmd160_obj   = asm/rm86-out.o
 | 
				
			||||||
$rc5_obj      = asm/r586-out.o
 | 
					$rc5_obj      = asm/r586-out.o
 | 
				
			||||||
$dso_scheme   = win32
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= cygwin-shared
 | 
					$shared_target= cygwin-shared
 | 
				
			||||||
$shared_cflag = 
 | 
					$shared_cflag = -D_WINDLL
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = 
 | 
				
			||||||
$shared_extension = .dll
 | 
					$shared_extension = .dll.a
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1027,6 +1027,56 @@ $arflags      =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
*** aix-cc
 | 
					*** aix-cc
 | 
				
			||||||
$cc           = cc
 | 
					$cc           = cc
 | 
				
			||||||
 | 
					$cflags       = -q32 -O -DB_ENDIAN -qmaxmem=16384
 | 
				
			||||||
 | 
					$unistd       = 
 | 
				
			||||||
 | 
					$thread_cflag = -qthreaded
 | 
				
			||||||
 | 
					$sys_id       = AIX
 | 
				
			||||||
 | 
					$lflags       = 
 | 
				
			||||||
 | 
					$bn_ops       = BN_LLONG RC4_CHAR
 | 
				
			||||||
 | 
					$bn_obj       = asm/aix_ppc32.o
 | 
				
			||||||
 | 
					$des_obj      = 
 | 
				
			||||||
 | 
					$bf_obj       = 
 | 
				
			||||||
 | 
					$md5_obj      = 
 | 
				
			||||||
 | 
					$sha1_obj     = 
 | 
				
			||||||
 | 
					$cast_obj     = 
 | 
				
			||||||
 | 
					$rc4_obj      = 
 | 
				
			||||||
 | 
					$rmd160_obj   = 
 | 
				
			||||||
 | 
					$rc5_obj      = 
 | 
				
			||||||
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
 | 
					$shared_target= aix-shared
 | 
				
			||||||
 | 
					$shared_cflag = 
 | 
				
			||||||
 | 
					$shared_ldflag = -q32
 | 
				
			||||||
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
 | 
					$ranlib       = 
 | 
				
			||||||
 | 
					$arflags      = -X 32
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					*** aix-gcc
 | 
				
			||||||
 | 
					$cc           = gcc
 | 
				
			||||||
 | 
					$cflags       = -O3 -DB_ENDIAN
 | 
				
			||||||
 | 
					$unistd       = 
 | 
				
			||||||
 | 
					$thread_cflag = -D_THREAD_SAFE
 | 
				
			||||||
 | 
					$sys_id       = AIX
 | 
				
			||||||
 | 
					$lflags       = 
 | 
				
			||||||
 | 
					$bn_ops       = BN_LLONG RC4_CHAR
 | 
				
			||||||
 | 
					$bn_obj       = asm/aix_ppc32.o
 | 
				
			||||||
 | 
					$des_obj      = 
 | 
				
			||||||
 | 
					$bf_obj       = 
 | 
				
			||||||
 | 
					$md5_obj      = 
 | 
				
			||||||
 | 
					$sha1_obj     = 
 | 
				
			||||||
 | 
					$cast_obj     = 
 | 
				
			||||||
 | 
					$rc4_obj      = 
 | 
				
			||||||
 | 
					$rmd160_obj   = 
 | 
				
			||||||
 | 
					$rc5_obj      = 
 | 
				
			||||||
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
 | 
					$shared_target= 
 | 
				
			||||||
 | 
					$shared_cflag = 
 | 
				
			||||||
 | 
					$shared_ldflag = 
 | 
				
			||||||
 | 
					$shared_extension = 
 | 
				
			||||||
 | 
					$ranlib       = 
 | 
				
			||||||
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					*** aix3-cc
 | 
				
			||||||
 | 
					$cc           = cc
 | 
				
			||||||
$cflags       = -O -DB_ENDIAN -qmaxmem=16384
 | 
					$cflags       = -O -DB_ENDIAN -qmaxmem=16384
 | 
				
			||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					$thread_cflag = (unknown)
 | 
				
			||||||
@@ -1050,90 +1100,15 @@ $shared_extension =
 | 
				
			|||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
*** aix-gcc
 | 
					 | 
				
			||||||
$cc           = gcc
 | 
					 | 
				
			||||||
$cflags       = -O3 -DB_ENDIAN
 | 
					 | 
				
			||||||
$unistd       = 
 | 
					 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					 | 
				
			||||||
$sys_id       = AIX
 | 
					 | 
				
			||||||
$lflags       = 
 | 
					 | 
				
			||||||
$bn_ops       = BN_LLONG RC4_CHAR
 | 
					 | 
				
			||||||
$bn_obj       = 
 | 
					 | 
				
			||||||
$des_obj      = 
 | 
					 | 
				
			||||||
$bf_obj       = 
 | 
					 | 
				
			||||||
$md5_obj      = 
 | 
					 | 
				
			||||||
$sha1_obj     = 
 | 
					 | 
				
			||||||
$cast_obj     = 
 | 
					 | 
				
			||||||
$rc4_obj      = 
 | 
					 | 
				
			||||||
$rmd160_obj   = 
 | 
					 | 
				
			||||||
$rc5_obj      = 
 | 
					 | 
				
			||||||
$dso_scheme   = 
 | 
					 | 
				
			||||||
$shared_target= 
 | 
					 | 
				
			||||||
$shared_cflag = 
 | 
					 | 
				
			||||||
$shared_ldflag = 
 | 
					 | 
				
			||||||
$shared_extension = 
 | 
					 | 
				
			||||||
$ranlib       = 
 | 
					 | 
				
			||||||
$arflags      = 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
*** aix43-cc
 | 
					 | 
				
			||||||
$cc           = cc
 | 
					 | 
				
			||||||
$cflags       = -O -DAIX -DB_ENDIAN -qmaxmem=16384
 | 
					 | 
				
			||||||
$unistd       = 
 | 
					 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					 | 
				
			||||||
$sys_id       = 
 | 
					 | 
				
			||||||
$lflags       = 
 | 
					 | 
				
			||||||
$bn_ops       = BN_LLONG RC4_CHAR
 | 
					 | 
				
			||||||
$bn_obj       = 
 | 
					 | 
				
			||||||
$des_obj      = 
 | 
					 | 
				
			||||||
$bf_obj       = 
 | 
					 | 
				
			||||||
$md5_obj      = 
 | 
					 | 
				
			||||||
$sha1_obj     = 
 | 
					 | 
				
			||||||
$cast_obj     = 
 | 
					 | 
				
			||||||
$rc4_obj      = 
 | 
					 | 
				
			||||||
$rmd160_obj   = 
 | 
					 | 
				
			||||||
$rc5_obj      = 
 | 
					 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					 | 
				
			||||||
$shared_target= aix-shared
 | 
					 | 
				
			||||||
$shared_cflag = 
 | 
					 | 
				
			||||||
$shared_ldflag = 
 | 
					 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					 | 
				
			||||||
$ranlib       = 
 | 
					 | 
				
			||||||
$arflags      = 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
*** aix43-gcc
 | 
					 | 
				
			||||||
$cc           = gcc
 | 
					 | 
				
			||||||
$cflags       = -O1 -DAIX -DB_ENDIAN
 | 
					 | 
				
			||||||
$unistd       = 
 | 
					 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					 | 
				
			||||||
$sys_id       = 
 | 
					 | 
				
			||||||
$lflags       = 
 | 
					 | 
				
			||||||
$bn_ops       = BN_LLONG RC4_CHAR
 | 
					 | 
				
			||||||
$bn_obj       = 
 | 
					 | 
				
			||||||
$des_obj      = 
 | 
					 | 
				
			||||||
$bf_obj       = 
 | 
					 | 
				
			||||||
$md5_obj      = 
 | 
					 | 
				
			||||||
$sha1_obj     = 
 | 
					 | 
				
			||||||
$cast_obj     = 
 | 
					 | 
				
			||||||
$rc4_obj      = 
 | 
					 | 
				
			||||||
$rmd160_obj   = 
 | 
					 | 
				
			||||||
$rc5_obj      = 
 | 
					 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					 | 
				
			||||||
$shared_target= 
 | 
					 | 
				
			||||||
$shared_cflag = 
 | 
					 | 
				
			||||||
$shared_ldflag = 
 | 
					 | 
				
			||||||
$shared_extension = 
 | 
					 | 
				
			||||||
$ranlib       = 
 | 
					 | 
				
			||||||
$arflags      = 
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
*** aix64-cc
 | 
					*** aix64-cc
 | 
				
			||||||
$cc           = cc
 | 
					$cc           = cc
 | 
				
			||||||
$cflags       = -O -DAIX -DB_ENDIAN -qmaxmem=16384 -q64
 | 
					$cflags       = -q64 -O -DB_ENDIAN -qmaxmem=16384
 | 
				
			||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					$thread_cflag = -qthreaded
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = AIX
 | 
				
			||||||
$lflags       = 
 | 
					$lflags       = 
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT_LONG RC4_CHAR
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG RC4_CHAR
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = asm/aix_ppc64.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
@@ -1452,13 +1427,13 @@ $arflags      =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
*** darwin-ppc-cc
 | 
					*** darwin-ppc-cc
 | 
				
			||||||
$cc           = cc
 | 
					$cc           = cc
 | 
				
			||||||
$cflags       = -O3 -fomit-frame-pointer -fno-common -DB_ENDIAN
 | 
					$cflags       = -O3 -fomit-frame-pointer -DB_ENDIAN
 | 
				
			||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = MACOSX
 | 
					$sys_id       = MACOSX
 | 
				
			||||||
$lflags       = 
 | 
					$lflags       = 
 | 
				
			||||||
$bn_ops       = BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR
 | 
					$bn_ops       = BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = asm/osx_ppc32.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
@@ -1467,9 +1442,9 @@ $cast_obj     =
 | 
				
			|||||||
$rc4_obj      = 
 | 
					$rc4_obj      = 
 | 
				
			||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = 
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= darwin-shared
 | 
					$shared_target= darwin-shared
 | 
				
			||||||
$shared_cflag = -fPIC
 | 
					$shared_cflag = -fPIC -fno-common
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = 
 | 
				
			||||||
$shared_extension = .$(SHLIB_MAJOR).$(SHLIB_MINOR).dylib
 | 
					$shared_extension = .$(SHLIB_MAJOR).$(SHLIB_MINOR).dylib
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
@@ -1920,7 +1895,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -1970,7 +1945,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2256,7 +2231,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -Ae +ESlit +O2 -z
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					$thread_cflag = (unknown)
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2270,7 +2245,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2281,7 +2256,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -O3
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					$thread_cflag = (unknown)
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2295,7 +2270,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fPIC
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2306,7 +2281,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O3 -z
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					$thread_cflag = (unknown)
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2320,7 +2295,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2331,7 +2306,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -O3
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = (unknown)
 | 
					$thread_cflag = (unknown)
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2345,7 +2320,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fPIC
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2356,22 +2331,22 @@ $cflags       = -Ae +DD32 +O3 +Olit=all -z -DB_ENDIAN
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldl
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = asm/ia64-cpp.o
 | 
					$bn_obj       = asm/ia64-cpp.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
$sha1_obj     = 
 | 
					$sha1_obj     = asm/sha1-ia64.o
 | 
				
			||||||
$cast_obj     = 
 | 
					$cast_obj     = 
 | 
				
			||||||
$rc4_obj      = 
 | 
					$rc4_obj      = asm/rc4-ia64.o
 | 
				
			||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2406,7 +2381,7 @@ $cflags       = +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DBN_DIV2W -DMD3
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+cdp,../:,+cdp,./:,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2420,7 +2395,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2431,7 +2406,7 @@ $cflags       = -Ae +O4 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = 
 | 
					$thread_cflag = 
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldld
 | 
					$lflags       = -Wl,+cdp,../:,+cdp,./:,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2445,7 +2420,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2456,7 +2431,7 @@ $cflags       = -O3 -DB_ENDIAN -DBN_DIV2W
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = 
 | 
					$thread_cflag = 
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+cdp,../:,+cdp,./:,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2470,7 +2445,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fPIC
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2481,7 +2456,7 @@ $cflags       = +DA1.1 +DS1.1 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -D
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+cdp,../:,+cdp,./:,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2495,7 +2470,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2506,7 +2481,7 @@ $cflags       = +DA2.0 +DS2.0 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -D
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+cdp,../:,+cdp,./:,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = asm/pa-risc2.o
 | 
					$bn_obj       = asm/pa-risc2.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2520,7 +2495,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2531,7 +2506,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -Ae +ESlit +O2 -z
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2545,7 +2520,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2556,7 +2531,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -O3
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2570,7 +2545,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fPIC
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2581,7 +2556,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O3 -z
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2595,7 +2570,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2606,7 +2581,7 @@ $cflags       = -DB_ENDIAN -DBN_DIV2W -O3
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -Wl,+s -ldld
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldld
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_UNROLL DES_RISC1
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2620,7 +2595,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dl
 | 
					$dso_scheme   = dl
 | 
				
			||||||
$shared_target= hpux-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fPIC
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2631,22 +2606,22 @@ $cflags       = -Ae +DD64 +O3 +Olit=all -z -DB_ENDIAN
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldl
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = asm/ia64-cpp.o
 | 
					$bn_obj       = asm/ia64-cpp.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
$sha1_obj     = 
 | 
					$sha1_obj     = asm/sha1-ia64.o
 | 
				
			||||||
$cast_obj     = 
 | 
					$cast_obj     = 
 | 
				
			||||||
$rc4_obj      = 
 | 
					$rc4_obj      = asm/rc4-ia64.o
 | 
				
			||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= hpux64-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = +DD64 -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -2656,7 +2631,7 @@ $cflags       = -Ae +DD64 +O3 +ESlit -z -DB_ENDIAN -DMD32_XARRAY
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldl
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2668,9 +2643,9 @@ $rc4_obj      =
 | 
				
			|||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= hpux64-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = +DD64 -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2681,7 +2656,7 @@ $cflags       = -DB_ENDIAN -DMD32_XARRAY
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldl
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = 
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2693,9 +2668,9 @@ $rc4_obj      =
 | 
				
			|||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= hpux64-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fpic
 | 
					$shared_cflag = -fpic
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2706,7 +2681,7 @@ $cflags       = +DD64 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XAR
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldl
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = asm/pa-risc2W.o
 | 
					$bn_obj       = asm/pa-risc2W.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2718,9 +2693,9 @@ $rc4_obj      =
 | 
				
			|||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= hpux64-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = +Z
 | 
					$shared_cflag = +Z
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = +DD64 -b
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -2731,7 +2706,7 @@ $cflags       = -O3 -DB_ENDIAN -DMD32_XARRAY
 | 
				
			|||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -Wl,+s,+b,$(INSTALLTOP)/lib -ldl
 | 
				
			||||||
$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT
 | 
				
			||||||
$bn_obj       = asm/pa-risc2W.o
 | 
					$bn_obj       = asm/pa-risc2W.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
@@ -2743,9 +2718,9 @@ $rc4_obj      =
 | 
				
			|||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= hpux64-shared
 | 
					$shared_target= hpux-shared
 | 
				
			||||||
$shared_cflag = -fpic
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -shared
 | 
				
			||||||
$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .sl.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -3077,7 +3052,7 @@ $arflags      =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
*** linux-elf-arm
 | 
					*** linux-elf-arm
 | 
				
			||||||
$cc           = gcc
 | 
					$cc           = gcc
 | 
				
			||||||
$cflags       = -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall
 | 
					$cflags       = -DTERMIO -O3 -fomit-frame-pointer -Wall
 | 
				
			||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
@@ -3112,9 +3087,9 @@ $bn_obj       = asm/ia64.o
 | 
				
			|||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
$sha1_obj     = 
 | 
					$sha1_obj     = asm/sha1-ia64.o
 | 
				
			||||||
$cast_obj     = 
 | 
					$cast_obj     = 
 | 
				
			||||||
$rc4_obj      = 
 | 
					$rc4_obj      = asm/rc4-ia64.o
 | 
				
			||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
@@ -3127,7 +3102,7 @@ $arflags      =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
*** linux-ia64-ecc
 | 
					*** linux-ia64-ecc
 | 
				
			||||||
$cc           = ecc
 | 
					$cc           = ecc
 | 
				
			||||||
$cflags       = -DL_ENDIAN -DTERMIO -O2 -Wall
 | 
					$cflags       = -DL_ENDIAN -DTERMIO -O2 -Wall -no_cpprt
 | 
				
			||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = -D_REENTRANT
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
@@ -3137,9 +3112,9 @@ $bn_obj       = asm/ia64.o
 | 
				
			|||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
$sha1_obj     = 
 | 
					$sha1_obj     = asm/sha1-ia64.o
 | 
				
			||||||
$cast_obj     = 
 | 
					$cast_obj     = 
 | 
				
			||||||
$rc4_obj      = 
 | 
					$rc4_obj      = asm/rc4-ia64.o
 | 
				
			||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
@@ -3308,7 +3283,7 @@ $thread_cflag = -D_REENTRANT
 | 
				
			|||||||
$sys_id       = 
 | 
					$sys_id       = 
 | 
				
			||||||
$lflags       = -ldl
 | 
					$lflags       = -ldl
 | 
				
			||||||
$bn_ops       = BN_LLONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL
 | 
					$bn_ops       = BN_LLONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL
 | 
				
			||||||
$bn_obj       = 
 | 
					$bn_obj       = asm/linux_ppc32.o
 | 
				
			||||||
$des_obj      = 
 | 
					$des_obj      = 
 | 
				
			||||||
$bf_obj       = 
 | 
					$bf_obj       = 
 | 
				
			||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
@@ -3325,6 +3300,31 @@ $shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			|||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					*** linux-ppc64
 | 
				
			||||||
 | 
					$cc           = gcc
 | 
				
			||||||
 | 
					$cflags       = -bpowerpc64-linux -DB_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -Wall
 | 
				
			||||||
 | 
					$unistd       = 
 | 
				
			||||||
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
 | 
					$sys_id       = 
 | 
				
			||||||
 | 
					$lflags       = -ldl
 | 
				
			||||||
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL
 | 
				
			||||||
 | 
					$bn_obj       = asm/linux_ppc64.o
 | 
				
			||||||
 | 
					$des_obj      = 
 | 
				
			||||||
 | 
					$bf_obj       = 
 | 
				
			||||||
 | 
					$md5_obj      = 
 | 
				
			||||||
 | 
					$sha1_obj     = 
 | 
				
			||||||
 | 
					$cast_obj     = 
 | 
				
			||||||
 | 
					$rc4_obj      = 
 | 
				
			||||||
 | 
					$rmd160_obj   = 
 | 
				
			||||||
 | 
					$rc5_obj      = 
 | 
				
			||||||
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
 | 
					$shared_target= linux-shared
 | 
				
			||||||
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
 | 
					$shared_ldflag = -bpowerpc64-linux
 | 
				
			||||||
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
 | 
					$ranlib       = 
 | 
				
			||||||
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
*** linux-ppro
 | 
					*** linux-ppro
 | 
				
			||||||
$cc           = gcc
 | 
					$cc           = gcc
 | 
				
			||||||
$cflags       = -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -mcpu=pentiumpro -Wall
 | 
					$cflags       = -DL_ENDIAN -DTERMIO -O3 -fomit-frame-pointer -mcpu=pentiumpro -Wall
 | 
				
			||||||
@@ -3489,7 +3489,7 @@ $bf_obj       =
 | 
				
			|||||||
$md5_obj      = 
 | 
					$md5_obj      = 
 | 
				
			||||||
$sha1_obj     = 
 | 
					$sha1_obj     = 
 | 
				
			||||||
$cast_obj     = 
 | 
					$cast_obj     = 
 | 
				
			||||||
$rc4_obj      = 
 | 
					$rc4_obj      = asm/rc4-x86_64.o
 | 
				
			||||||
$rmd160_obj   = 
 | 
					$rmd160_obj   = 
 | 
				
			||||||
$rc5_obj      = 
 | 
					$rc5_obj      = 
 | 
				
			||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
@@ -3527,12 +3527,12 @@ $arflags      =
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
*** mingw
 | 
					*** mingw
 | 
				
			||||||
$cc           = gcc
 | 
					$cc           = gcc
 | 
				
			||||||
$cflags       = -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -mno-cygwin -Wall
 | 
					$cflags       = -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -mno-cygwin -Wall -D_WIN32_WINNT=0x333
 | 
				
			||||||
$unistd       = 
 | 
					$unistd       = 
 | 
				
			||||||
$thread_cflag = 
 | 
					$thread_cflag = 
 | 
				
			||||||
$sys_id       = MINGW32
 | 
					$sys_id       = MINGW32
 | 
				
			||||||
$lflags       = -mno-cygwin -lwsock32 -lgdi32
 | 
					$lflags       = -lwsock32 -lgdi32
 | 
				
			||||||
$bn_ops       = BN_LLONG DES_PTR DES_RISC1 DES_UNROLL RC4_INDEX MD2_INT
 | 
					$bn_ops       = BN_LLONG DES_PTR DES_RISC1 DES_UNROLL RC4_INDEX MD2_INT EXPORT_VAR_AS_FN
 | 
				
			||||||
$bn_obj       = asm/bn86-out.o asm/co86-out.o
 | 
					$bn_obj       = asm/bn86-out.o asm/co86-out.o
 | 
				
			||||||
$des_obj      = asm/dx86-out.o asm/yx86-out.o
 | 
					$des_obj      = asm/dx86-out.o asm/yx86-out.o
 | 
				
			||||||
$bf_obj       = asm/bx86-out.o
 | 
					$bf_obj       = asm/bx86-out.o
 | 
				
			||||||
@@ -3543,10 +3543,10 @@ $rc4_obj      = asm/rx86-out.o
 | 
				
			|||||||
$rmd160_obj   = asm/rm86-out.o
 | 
					$rmd160_obj   = asm/rm86-out.o
 | 
				
			||||||
$rc5_obj      = asm/r586-out.o
 | 
					$rc5_obj      = asm/r586-out.o
 | 
				
			||||||
$dso_scheme   = win32
 | 
					$dso_scheme   = win32
 | 
				
			||||||
$shared_target= 
 | 
					$shared_target= cygwin-shared
 | 
				
			||||||
$shared_cflag = 
 | 
					$shared_cflag = -D_WINDLL
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -mno-cygwin
 | 
				
			||||||
$shared_extension = .dll
 | 
					$shared_extension = .dll.a
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -3845,7 +3845,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -3870,7 +3870,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -3970,7 +3970,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -4045,7 +4045,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = 
 | 
					$shared_ldflag = -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -4095,7 +4095,7 @@ $rc5_obj      =
 | 
				
			|||||||
$dso_scheme   = dlfcn
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
$shared_target= solaris-shared
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
$shared_cflag = -KPIC
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
$shared_ldflag = -xarch=v9
 | 
					$shared_ldflag = -xarch=v9 -G -dy -z text
 | 
				
			||||||
$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
$ranlib       = /usr/ccs/bin/ar rs
 | 
					$ranlib       = /usr/ccs/bin/ar rs
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
@@ -4150,6 +4150,56 @@ $shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			|||||||
$ranlib       = 
 | 
					$ranlib       = 
 | 
				
			||||||
$arflags      = 
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					*** solaris64-x86_64-cc
 | 
				
			||||||
 | 
					$cc           = cc
 | 
				
			||||||
 | 
					$cflags       = -fast -xarch=amd64 -xstrconst -Xa -DL_ENDIAN
 | 
				
			||||||
 | 
					$unistd       = 
 | 
				
			||||||
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
 | 
					$sys_id       = 
 | 
				
			||||||
 | 
					$lflags       = -lsocket -lnsl -ldl
 | 
				
			||||||
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR BF_PTR2 DES_INT DES_UNROLL
 | 
				
			||||||
 | 
					$bn_obj       = 
 | 
				
			||||||
 | 
					$des_obj      = 
 | 
				
			||||||
 | 
					$bf_obj       = 
 | 
				
			||||||
 | 
					$md5_obj      = 
 | 
				
			||||||
 | 
					$sha1_obj     = 
 | 
				
			||||||
 | 
					$cast_obj     = 
 | 
				
			||||||
 | 
					$rc4_obj      = 
 | 
				
			||||||
 | 
					$rmd160_obj   = 
 | 
				
			||||||
 | 
					$rc5_obj      = 
 | 
				
			||||||
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
 | 
					$shared_cflag = -KPIC
 | 
				
			||||||
 | 
					$shared_ldflag = -xarch=amd64 -G -dy -z text
 | 
				
			||||||
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
 | 
					$ranlib       = 
 | 
				
			||||||
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					*** solaris64-x86_64-gcc
 | 
				
			||||||
 | 
					$cc           = gcc
 | 
				
			||||||
 | 
					$cflags       = -m64 -O3 -Wall -DL_ENDIAN -DMD32_REG_T=int
 | 
				
			||||||
 | 
					$unistd       = 
 | 
				
			||||||
 | 
					$thread_cflag = -D_REENTRANT
 | 
				
			||||||
 | 
					$sys_id       = 
 | 
				
			||||||
 | 
					$lflags       = -lsocket -lnsl -ldl
 | 
				
			||||||
 | 
					$bn_ops       = SIXTY_FOUR_BIT_LONG RC4_CHUNK RC4_CHAR BF_PTR2 DES_INT DES_UNROLL
 | 
				
			||||||
 | 
					$bn_obj       = asm/x86_64-gcc.o
 | 
				
			||||||
 | 
					$des_obj      = 
 | 
				
			||||||
 | 
					$bf_obj       = 
 | 
				
			||||||
 | 
					$md5_obj      = 
 | 
				
			||||||
 | 
					$sha1_obj     = 
 | 
				
			||||||
 | 
					$cast_obj     = 
 | 
				
			||||||
 | 
					$rc4_obj      = asm/rc4-x86_64.o
 | 
				
			||||||
 | 
					$rmd160_obj   = 
 | 
				
			||||||
 | 
					$rc5_obj      = 
 | 
				
			||||||
 | 
					$dso_scheme   = dlfcn
 | 
				
			||||||
 | 
					$shared_target= solaris-shared
 | 
				
			||||||
 | 
					$shared_cflag = -fPIC
 | 
				
			||||||
 | 
					$shared_ldflag = -m64 -shared -static-libgcc
 | 
				
			||||||
 | 
					$shared_extension = .so.$(SHLIB_MAJOR).$(SHLIB_MINOR)
 | 
				
			||||||
 | 
					$ranlib       = 
 | 
				
			||||||
 | 
					$arflags      = 
 | 
				
			||||||
 | 
					
 | 
				
			||||||
*** sunos-gcc
 | 
					*** sunos-gcc
 | 
				
			||||||
$cc           = gcc
 | 
					$cc           = gcc
 | 
				
			||||||
$cflags       = -O3 -mv8 -Dssize_t=int
 | 
					$cflags       = -O3 -mv8 -Dssize_t=int
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,3 +4,5 @@ der_chop
 | 
				
			|||||||
der_chop.bak
 | 
					der_chop.bak
 | 
				
			||||||
CA.pl
 | 
					CA.pl
 | 
				
			||||||
openssl.sha1
 | 
					openssl.sha1
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -36,13 +36,21 @@
 | 
				
			|||||||
# 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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					my $openssl;
 | 
				
			||||||
 | 
					if(defined $ENV{OPENSSL}) {
 | 
				
			||||||
 | 
						$openssl = $ENV{OPENSSL};
 | 
				
			||||||
 | 
					} else {
 | 
				
			||||||
 | 
						$openssl = "openssl";
 | 
				
			||||||
 | 
						$ENV{OPENSSL} = $openssl;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$SSLEAY_CONFIG=$ENV{"SSLEAY_CONFIG"};
 | 
					$SSLEAY_CONFIG=$ENV{"SSLEAY_CONFIG"};
 | 
				
			||||||
$DAYS="-days 365";
 | 
					$DAYS="-days 365";
 | 
				
			||||||
$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";
 | 
					$PKCS12="$openssl pkcs12";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$CATOP="./demoCA";
 | 
					$CATOP="./demoCA";
 | 
				
			||||||
$CAKEY="cakey.pem";
 | 
					$CAKEY="cakey.pem";
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								apps/CA.sh
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								apps/CA.sh
									
									
									
									
									
								
							@@ -30,11 +30,13 @@
 | 
				
			|||||||
# 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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if [ -z "$OPENSSL" ]; then OPENSSL=openssl; fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
DAYS="-days 365"
 | 
					DAYS="-days 365"
 | 
				
			||||||
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"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
CATOP=./demoCA
 | 
					CATOP=./demoCA
 | 
				
			||||||
CAKEY=./cakey.pem
 | 
					CAKEY=./cakey.pem
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -36,7 +36,7 @@ LIBSSL=-L.. -lssl
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
PROGRAM= openssl
 | 
					PROGRAM= openssl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SCRIPTS=CA.sh CA.pl der_chop
 | 
					SCRIPTS=CA.sh CA.pl
 | 
				
			||||||
 | 
					
 | 
				
			||||||
EXE= $(PROGRAM)$(EXE_EXT)
 | 
					EXE= $(PROGRAM)$(EXE_EXT)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -101,8 +101,17 @@ install:
 | 
				
			|||||||
	(echo installing $$i; \
 | 
						(echo installing $$i; \
 | 
				
			||||||
	 cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \
 | 
						 cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \
 | 
				
			||||||
	 chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \
 | 
						 chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new; \
 | 
				
			||||||
	 mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i ); \
 | 
						 mv -f  $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i.new \
 | 
				
			||||||
	 done;
 | 
						 	$(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$i; \
 | 
				
			||||||
 | 
						 sig="$$i.$${HMAC_EXT:-sha1}"; \
 | 
				
			||||||
 | 
						 if [ -f $$sig ]; then \
 | 
				
			||||||
 | 
						  echo installing $$sig; \
 | 
				
			||||||
 | 
						  cp $$sig $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$sig.new; \
 | 
				
			||||||
 | 
						  chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$sig.new; \
 | 
				
			||||||
 | 
						  mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$sig.new \
 | 
				
			||||||
 | 
							$(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$sig; \
 | 
				
			||||||
 | 
						 fi; \
 | 
				
			||||||
 | 
						) done;
 | 
				
			||||||
	@for i in $(SCRIPTS); \
 | 
						@for i in $(SCRIPTS); \
 | 
				
			||||||
	do  \
 | 
						do  \
 | 
				
			||||||
	(echo installing $$i; \
 | 
						(echo installing $$i; \
 | 
				
			||||||
@@ -143,23 +152,24 @@ $(DLIBCRYPTO):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
$(EXE): progs.h $(E_OBJ) $(PROGRAM).o $(DLIBCRYPTO) $(DLIBSSL)
 | 
					$(EXE): progs.h $(E_OBJ) $(PROGRAM).o $(DLIBCRYPTO) $(DLIBSSL)
 | 
				
			||||||
	$(RM) $(EXE)
 | 
						$(RM) $(EXE)
 | 
				
			||||||
	if [ "$(SHLIB_TARGET)" = "hpux-shared" -o "$(SHLIB_TARGET)" = "darwin-shared" ] ; then \
 | 
						SHARED_LIBS="$(SHARED_LIBS)"; \
 | 
				
			||||||
	  $(CC) -o $(EXE) $(CFLAGS) $(PROGRAM).o $(E_OBJ) $(PEX_LIBS) $(DLIBSSL) $(LIBKRB5) $(DLIBCRYPTO) $(EX_LIBS) ; \
 | 
						if [ "$(SHLIB_TARGET)" = "darwin-shared" ] ; then \
 | 
				
			||||||
 | 
						  SHARED_LIBS=""; \
 | 
				
			||||||
 | 
						fi; \
 | 
				
			||||||
 | 
						if [ -z "$(SHARED_LIBS)" ]; then \
 | 
				
			||||||
 | 
						  set -x; $${CC:-$(CC)} -o $(EXE) $(CFLAGS) $(PROGRAM).o $(E_OBJ) $(PEX_LIBS) $(DLIBSSL) $(LIBKRB5) $(DLIBCRYPTO) $(EX_LIBS) ; \
 | 
				
			||||||
	else \
 | 
						else \
 | 
				
			||||||
	  LD_LIBRARY_PATH=..:$$LD_LIBRARY_PATH \
 | 
						  set -x; LD_LIBRARY_PATH=..:$$LD_LIBRARY_PATH \
 | 
				
			||||||
	  $(CC) -o $(EXE) $(CFLAGS) $(PROGRAM).o $(E_OBJ) $(PEX_LIBS) $(LIBSSL) $(LIBKRB5) $(LIBCRYPTO) $(EX_LIBS) ; \
 | 
						  $(CC) -o $(EXE) $(CFLAGS) $(PROGRAM).o $(E_OBJ) $(PEX_LIBS) $(LIBSSL) $(LIBKRB5) $(LIBCRYPTO) $(EX_LIBS) ; \
 | 
				
			||||||
 | 
						fi; \
 | 
				
			||||||
 | 
						if [ -z "$$SHARED_LIBS" ]; then \
 | 
				
			||||||
 | 
						  if egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null; then \
 | 
				
			||||||
 | 
						    TOP=$(TOP) $(TOP)/fips/openssl_fips_fingerprint $(TOP)/libcrypto.a $(EXE); \
 | 
				
			||||||
 | 
						  fi; \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	if egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null; then \
 | 
						-(cd ..; \
 | 
				
			||||||
		TOP=$(TOP) $(TOP)/fips/openssl_fips_fingerprint $(TOP)/libcrypto.a $(EXE); \
 | 
						  OPENSSL="`pwd`/util/opensslwrap.sh"; export OPENSSL; \
 | 
				
			||||||
	fi
 | 
						  $(PERL) tools/c_rehash certs)
 | 
				
			||||||
	-(cd ..; OPENSSL="`pwd`/apps/$(EXE)"; export OPENSSL; \
 | 
					 | 
				
			||||||
		LD_LIBRARY_PATH="`pwd`:$$LD_LIBRARY_PATH"; \
 | 
					 | 
				
			||||||
		DYLD_LIBRARY_PATH="`pwd`:$$DYLD_LIBRARY_PATH"; \
 | 
					 | 
				
			||||||
		SHLIB_PATH="`pwd`:$$SHLIB_PATH"; \
 | 
					 | 
				
			||||||
		LIBPATH="`pwd`:$$LIBPATH"; \
 | 
					 | 
				
			||||||
		if [ "$(PLATFORM)" = "Cygwin" ]; then PATH="`pwd`:$$PATH"; fi; \
 | 
					 | 
				
			||||||
		export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH PATH; \
 | 
					 | 
				
			||||||
		$(PERL) tools/c_rehash certs)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
progs.h: progs.pl
 | 
					progs.h: progs.pl
 | 
				
			||||||
	$(PERL) progs.pl $(E_EXE) >progs.h
 | 
						$(PERL) progs.pl $(E_EXE) >progs.h
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										89
									
								
								apps/apps.c
									
									
									
									
									
								
							
							
						
						
									
										89
									
								
								apps/apps.c
									
									
									
									
									
								
							@@ -330,22 +330,6 @@ void program_name(char *in, char *out, int size)
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					 | 
				
			||||||
int VMS_strcasecmp(const char *str1, const char *str2)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	while (*str1 && *str2)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		int res = toupper(*str1) - toupper(*str2);
 | 
					 | 
				
			||||||
		if (res) return res < 0 ? -1 : 1;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	if (*str1)
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
	if (*str2)
 | 
					 | 
				
			||||||
		return -1;
 | 
					 | 
				
			||||||
	return 0;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int chopup_args(ARGS *arg, char *buf, int *argc, char **argv[])
 | 
					int chopup_args(ARGS *arg, char *buf, int *argc, char **argv[])
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int num,len,i;
 | 
						int num,len,i;
 | 
				
			||||||
@@ -542,7 +526,7 @@ int password_callback(char *buf, int bufsiz, int verify,
 | 
				
			|||||||
		char *prompt = NULL;
 | 
							char *prompt = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		prompt = UI_construct_prompt(ui, "pass phrase",
 | 
							prompt = UI_construct_prompt(ui, "pass phrase",
 | 
				
			||||||
			cb_data->prompt_info);
 | 
								prompt_info);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		ui_flags |= UI_INPUT_FLAG_DEFAULT_PWD;
 | 
							ui_flags |= UI_INPUT_FLAG_DEFAULT_PWD;
 | 
				
			||||||
		UI_ctrl(ui, UI_CTRL_PRINT_ERRORS, 1, 0, 0);
 | 
							UI_ctrl(ui, UI_CTRL_PRINT_ERRORS, 1, 0, 0);
 | 
				
			||||||
@@ -691,6 +675,51 @@ int add_oid_section(BIO *err, CONF *conf)
 | 
				
			|||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int load_pkcs12(BIO *err, BIO *in, const char *desc,
 | 
				
			||||||
 | 
							pem_password_cb *pem_cb,  void *cb_data,
 | 
				
			||||||
 | 
							EVP_PKEY **pkey, X509 **cert, STACK_OF(X509) **ca)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
					 	const char *pass;
 | 
				
			||||||
 | 
						char tpass[PEM_BUFSIZE];
 | 
				
			||||||
 | 
						int len, ret = 0;
 | 
				
			||||||
 | 
						PKCS12 *p12;
 | 
				
			||||||
 | 
						p12 = d2i_PKCS12_bio(in, NULL);
 | 
				
			||||||
 | 
						if (p12 == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIO_printf(err, "Error loading PKCS12 file for %s\n", desc);	
 | 
				
			||||||
 | 
							goto die;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						/* See if an empty password will do */
 | 
				
			||||||
 | 
						if (PKCS12_verify_mac(p12, "", 0) || PKCS12_verify_mac(p12, NULL, 0))
 | 
				
			||||||
 | 
							pass = "";
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							if (!pem_cb)
 | 
				
			||||||
 | 
								pem_cb = (pem_password_cb *)password_callback;
 | 
				
			||||||
 | 
							len = pem_cb(tpass, PEM_BUFSIZE, 0, cb_data);
 | 
				
			||||||
 | 
							if (len < 0) 
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(err, "Passpharse callback error for %s\n",
 | 
				
			||||||
 | 
										desc);
 | 
				
			||||||
 | 
								goto die;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							if (len < PEM_BUFSIZE)
 | 
				
			||||||
 | 
								tpass[len] = 0;
 | 
				
			||||||
 | 
							if (!PKCS12_verify_mac(p12, tpass, len))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(err,
 | 
				
			||||||
 | 
						"Mac verify error (wrong password?) in PKCS12 file for %s\n", desc);	
 | 
				
			||||||
 | 
								goto die;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							pass = tpass;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						ret = PKCS12_parse(p12, pass, pkey, cert, ca);
 | 
				
			||||||
 | 
						die:
 | 
				
			||||||
 | 
						if (p12)
 | 
				
			||||||
 | 
							PKCS12_free(p12);
 | 
				
			||||||
 | 
						return ret;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
X509 *load_cert(BIO *err, const char *file, int format,
 | 
					X509 *load_cert(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)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
@@ -771,11 +800,9 @@ X509 *load_cert(BIO *err, const char *file, int format,
 | 
				
			|||||||
			(pem_password_cb *)password_callback, NULL);
 | 
								(pem_password_cb *)password_callback, NULL);
 | 
				
			||||||
	else if (format == FORMAT_PKCS12)
 | 
						else if (format == FORMAT_PKCS12)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		PKCS12 *p12 = d2i_PKCS12_bio(cert, NULL);
 | 
							if (!load_pkcs12(err, cert,cert_descrip, NULL, NULL,
 | 
				
			||||||
 | 
										NULL, &x, NULL))
 | 
				
			||||||
		PKCS12_parse(p12, NULL, NULL, &x, NULL);
 | 
								goto end;
 | 
				
			||||||
		PKCS12_free(p12);
 | 
					 | 
				
			||||||
		p12 = NULL;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else	{
 | 
						else	{
 | 
				
			||||||
		BIO_printf(err,"bad input format specified for %s\n",
 | 
							BIO_printf(err,"bad input format specified for %s\n",
 | 
				
			||||||
@@ -854,11 +881,10 @@ EVP_PKEY *load_key(BIO *err, const char *file, int format, int maybe_stdin,
 | 
				
			|||||||
#endif
 | 
					#endif
 | 
				
			||||||
	else if (format == FORMAT_PKCS12)
 | 
						else if (format == FORMAT_PKCS12)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		PKCS12 *p12 = d2i_PKCS12_bio(key, NULL);
 | 
							if (!load_pkcs12(err, key, key_descrip,
 | 
				
			||||||
 | 
									(pem_password_cb *)password_callback, &cb_data,
 | 
				
			||||||
		PKCS12_parse(p12, pass, &pkey, NULL, NULL);
 | 
									&pkey, NULL, NULL))
 | 
				
			||||||
		PKCS12_free(p12);
 | 
								goto end;
 | 
				
			||||||
		p12 = NULL;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -1565,8 +1591,9 @@ int rotate_serial(char *serialfile, char *new_suffix, char *old_suffix)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (errno != ENOENT 
 | 
							if (errno != ENOENT 
 | 
				
			||||||
#ifdef ENOTDIR
 | 
					#ifdef ENOTDIR
 | 
				
			||||||
			&& errno != ENOTDIR)
 | 
								&& errno != ENOTDIR
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
							   )
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -1867,8 +1894,9 @@ int rotate_index(char *dbfile, char *new_suffix, char *old_suffix)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (errno != ENOENT 
 | 
							if (errno != ENOENT 
 | 
				
			||||||
#ifdef ENOTDIR
 | 
					#ifdef ENOTDIR
 | 
				
			||||||
			&& errno != ENOTDIR)
 | 
								&& errno != ENOTDIR
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
							   )
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -1903,8 +1931,9 @@ int rotate_index(char *dbfile, char *new_suffix, char *old_suffix)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (errno != ENOENT 
 | 
							if (errno != ENOENT 
 | 
				
			||||||
#ifdef ENOTDIR
 | 
					#ifdef ENOTDIR
 | 
				
			||||||
			&& errno != ENOTDIR)
 | 
								&& errno != ENOTDIR
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
							   )
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										41
									
								
								apps/ca.c
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								apps/ca.c
									
									
									
									
									
								
							@@ -994,25 +994,27 @@ bad:
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if ((md == NULL) && ((md=NCONF_get_string(conf,
 | 
				
			||||||
 | 
							section,ENV_DEFAULT_MD)) == NULL))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							lookup_fail(section,ENV_DEFAULT_MD);
 | 
				
			||||||
 | 
							goto err;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if ((dgst=EVP_get_digestbyname(md)) == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIO_printf(bio_err,"%s is an unsupported message digest type\n",md);
 | 
				
			||||||
 | 
							goto err;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (req)
 | 
						if (req)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		if ((md == NULL) && ((md=NCONF_get_string(conf,
 | 
					 | 
				
			||||||
			section,ENV_DEFAULT_MD)) == NULL))
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			lookup_fail(section,ENV_DEFAULT_MD);
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if ((email_dn == 1) && ((tmp_email_dn=NCONF_get_string(conf,
 | 
							if ((email_dn == 1) && ((tmp_email_dn=NCONF_get_string(conf,
 | 
				
			||||||
			section,ENV_DEFAULT_EMAIL_DN)) != NULL ))
 | 
								section,ENV_DEFAULT_EMAIL_DN)) != NULL ))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if(strcmp(tmp_email_dn,"no") == 0)
 | 
								if(strcmp(tmp_email_dn,"no") == 0)
 | 
				
			||||||
				email_dn=0;
 | 
									email_dn=0;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		if ((dgst=EVP_get_digestbyname(md)) == NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			BIO_printf(bio_err,"%s is an unsupported message digest type\n",md);
 | 
					 | 
				
			||||||
			goto err;
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		if (verbose)
 | 
							if (verbose)
 | 
				
			||||||
			BIO_printf(bio_err,"message digest is %s\n",
 | 
								BIO_printf(bio_err,"message digest is %s\n",
 | 
				
			||||||
				OBJ_nid2ln(dgst->type));
 | 
									OBJ_nid2ln(dgst->type));
 | 
				
			||||||
@@ -1395,23 +1397,10 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		/* we now have a CRL */
 | 
							/* we now have a CRL */
 | 
				
			||||||
		if (verbose) BIO_printf(bio_err,"signing CRL\n");
 | 
							if (verbose) BIO_printf(bio_err,"signing CRL\n");
 | 
				
			||||||
		if (md != NULL)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			if ((dgst=EVP_get_digestbyname(md)) == NULL)
 | 
					 | 
				
			||||||
				{
 | 
					 | 
				
			||||||
				BIO_printf(bio_err,"%s is an unsupported message digest type\n",md);
 | 
					 | 
				
			||||||
				goto err;
 | 
					 | 
				
			||||||
				}
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		else
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
#ifndef OPENSSL_NO_DSA
 | 
					#ifndef OPENSSL_NO_DSA
 | 
				
			||||||
			if (pkey->type == EVP_PKEY_DSA) 
 | 
							if (pkey->type == EVP_PKEY_DSA) 
 | 
				
			||||||
				dgst=EVP_dss1();
 | 
								dgst=EVP_dss1();
 | 
				
			||||||
			else
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
				dgst=EVP_md5();
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
		/* Add any extensions asked for */
 | 
							/* Add any extensions asked for */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -355,7 +355,11 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (text) X509_CRL_print(out, x);
 | 
						if (text) X509_CRL_print(out, x);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (noout) goto end;
 | 
						if (noout) 
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ret = 0;
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if 	(outformat == FORMAT_ASN1)
 | 
						if 	(outformat == FORMAT_ASN1)
 | 
				
			||||||
		i=(int)i2d_X509_CRL_bio(out,x);
 | 
							i=(int)i2d_X509_CRL_bio(out,x);
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										305
									
								
								apps/der_chop.in
									
									
									
									
									
								
							
							
						
						
									
										305
									
								
								apps/der_chop.in
									
									
									
									
									
								
							@@ -1,305 +0,0 @@
 | 
				
			|||||||
#!/usr/local/bin/perl
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# der_chop ... this is one total hack that Eric is really not proud of
 | 
					 | 
				
			||||||
#              so don't look at it and don't ask for support
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# The "documentation" for this (i.e. all the comments) are my fault --tjh
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# This program takes the "raw" output of derparse/asn1parse and 
 | 
					 | 
				
			||||||
# converts it into tokens and then runs regular expression matches
 | 
					 | 
				
			||||||
# to try to figure out what to grab to get the things that are needed
 | 
					 | 
				
			||||||
# and it is possible that this will do the wrong thing as it is a *hack*
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# SSLeay 0.5.2+ should have direct read support for x509 (via -inform NET)
 | 
					 | 
				
			||||||
# [I know ... promises promises :-)]
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# To convert a Netscape Certificate:
 | 
					 | 
				
			||||||
#    der_chop < ServerCert.der > cert.pem
 | 
					 | 
				
			||||||
# To convert a Netscape Key (and encrypt it again to protect it)
 | 
					 | 
				
			||||||
#    rsa -inform NET -in ServerKey.der -des > key.pem
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# 23-Apr-96 eay    Added the extra ASN.1 string types, I still think this
 | 
					 | 
				
			||||||
#		   is an evil hack.  If nothing else the parsing should
 | 
					 | 
				
			||||||
#		   be relative, not absolute.
 | 
					 | 
				
			||||||
# 19-Apr-96 tjh    hacked (with eay) into 0.5.x format
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
# Tim Hudson
 | 
					 | 
				
			||||||
# tjh@cryptsoft.com
 | 
					 | 
				
			||||||
#
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
require 'getopts.pl';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
$debug=0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# this was the 0.4.x way of doing things ...
 | 
					 | 
				
			||||||
$cmd="derparse";
 | 
					 | 
				
			||||||
$x509_cmd="x509";
 | 
					 | 
				
			||||||
$crl_cmd="crl";
 | 
					 | 
				
			||||||
$rc4_cmd="rc4";
 | 
					 | 
				
			||||||
$md2_cmd="md2";
 | 
					 | 
				
			||||||
$md4_cmd="md4";
 | 
					 | 
				
			||||||
$rsa_cmd="rsa -des -inform der ";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# this was the 0.5.x way of doing things ...
 | 
					 | 
				
			||||||
$cmd="openssl asn1parse";
 | 
					 | 
				
			||||||
$x509_cmd="openssl x509";
 | 
					 | 
				
			||||||
$crl_cmd="openssl crl";
 | 
					 | 
				
			||||||
$rc4_cmd="openssl rc4";
 | 
					 | 
				
			||||||
$md2_cmd="openssl md2";
 | 
					 | 
				
			||||||
$md4_cmd="openssl md4";
 | 
					 | 
				
			||||||
$rsa_cmd="openssl rsa -des -inform der ";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
&Getopts('vd:') || die "usage:$0 [-v] [-d num] file";
 | 
					 | 
				
			||||||
$depth=($opt_d =~ /^\d+$/)?$opt_d:0;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
&init_der();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
if ($#ARGV != -1)
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	foreach $file (@ARGV)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		print STDERR "doing $file\n";
 | 
					 | 
				
			||||||
		&dofile($file);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
else
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$file="/tmp/a$$.DER";
 | 
					 | 
				
			||||||
	open(OUT,">$file") || die "unable to open $file:$!\n";
 | 
					 | 
				
			||||||
	for (;;)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		$i=sysread(STDIN,$b,1024*10);
 | 
					 | 
				
			||||||
		last if ($i <= 0);
 | 
					 | 
				
			||||||
		$i=syswrite(OUT,$b,$i);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	&dofile($file);
 | 
					 | 
				
			||||||
	unlink($file);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
sub dofile
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($file)=@_;
 | 
					 | 
				
			||||||
	local(@p);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	$b=&load_file($file);
 | 
					 | 
				
			||||||
	@p=&load_file_parse($file);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	foreach $_ (@p)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		($off,$d,$hl,$len)=&parse_line($_);
 | 
					 | 
				
			||||||
		$d-=$depth;
 | 
					 | 
				
			||||||
		next if ($d != 0);
 | 
					 | 
				
			||||||
		next if ($len == 0);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		$o=substr($b,$off,$len+$hl);
 | 
					 | 
				
			||||||
		($str,@data)=&der_str($o);
 | 
					 | 
				
			||||||
		print "$str\n" if ($opt_v);
 | 
					 | 
				
			||||||
		if ($str =~ /^$crl/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			open(OUT,"|$crl_cmd -inform d -hash -issuer") ||
 | 
					 | 
				
			||||||
				die "unable to run $crl_cmd:$!\n";
 | 
					 | 
				
			||||||
			print OUT $o;
 | 
					 | 
				
			||||||
			close(OUT);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif ($str =~ /^$x509/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			open(OUT,"|$x509_cmd -inform d -hash -subject -issuer")
 | 
					 | 
				
			||||||
				|| die "unable to run $x509_cmd:$!\n";
 | 
					 | 
				
			||||||
			print OUT $o;
 | 
					 | 
				
			||||||
			close(OUT);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif ($str =~ /^$rsa/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			($type)=($data[3] =~ /OBJECT_IDENTIFIER :(.*)\s*$/);
 | 
					 | 
				
			||||||
			next unless ($type eq "rsaEncryption");
 | 
					 | 
				
			||||||
			($off,$d,$hl,$len)=&parse_line($data[5]);
 | 
					 | 
				
			||||||
			$os=substr($o,$off+$hl,$len);
 | 
					 | 
				
			||||||
			open(OUT,"|$rsa_cmd")
 | 
					 | 
				
			||||||
				|| die "unable to run $rsa_cmd:$!\n";
 | 
					 | 
				
			||||||
			print OUT $os;
 | 
					 | 
				
			||||||
			close(OUT);
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		elsif ($str =~ /^0G-1D-1G/)
 | 
					 | 
				
			||||||
			{
 | 
					 | 
				
			||||||
			($off,$d,$hl,$len)=&parse_line($data[1]);
 | 
					 | 
				
			||||||
			$os=substr($o,$off+$hl,$len);
 | 
					 | 
				
			||||||
			print STDERR "<$os>\n" if $opt_v;
 | 
					 | 
				
			||||||
			&do_certificate($o,@data)
 | 
					 | 
				
			||||||
				if (($os eq "certificate") &&
 | 
					 | 
				
			||||||
				    ($str =! /^0G-1D-1G-2G-3F-3E-2D/));
 | 
					 | 
				
			||||||
			&do_private_key($o,@data)
 | 
					 | 
				
			||||||
				if (($os eq "private-key") &&
 | 
					 | 
				
			||||||
				    ($str =! /^0G-1D-1G-2G-3F-3E-2D/));
 | 
					 | 
				
			||||||
			}
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub der_str
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($str)=@_;
 | 
					 | 
				
			||||||
	local(*OUT,*IN,@a,$t,$d,$ret);
 | 
					 | 
				
			||||||
	local($file)="/tmp/b$$.DER";
 | 
					 | 
				
			||||||
	local(@ret);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	open(OUT,">$file");
 | 
					 | 
				
			||||||
	print OUT $str;
 | 
					 | 
				
			||||||
	close(OUT);
 | 
					 | 
				
			||||||
	open(IN,"$cmd -inform 'd' -in $file |") ||
 | 
					 | 
				
			||||||
		die "unable to run $cmd:$!\n";
 | 
					 | 
				
			||||||
	$ret="";
 | 
					 | 
				
			||||||
	while (<IN>)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		chop;
 | 
					 | 
				
			||||||
		push(@ret,$_);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		print STDERR "$_\n" if ($debug);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		@a=split(/\s*:\s*/);
 | 
					 | 
				
			||||||
		($d)=($a[1] =~ /d=\s*(\d+)/);
 | 
					 | 
				
			||||||
		$a[2] =~ s/\s+$//;
 | 
					 | 
				
			||||||
		$t=$DER_s2i{$a[2]};
 | 
					 | 
				
			||||||
		$ret.="$d$t-";
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	close(IN);
 | 
					 | 
				
			||||||
	unlink($file);
 | 
					 | 
				
			||||||
	chop $ret;
 | 
					 | 
				
			||||||
	$ret =~ s/(-3H(-4G-5F-5[IJKMQRS])+)+/-NAME/g;
 | 
					 | 
				
			||||||
	$ret =~ s/(-3G-4B-4L)+/-RCERT/g;
 | 
					 | 
				
			||||||
	return($ret,@ret);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub init_der
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	$crl= "0G-1G-2G-3F-3E-2G-NAME-2L-2L-2G-RCERT-1G-2F-2E-1C";
 | 
					 | 
				
			||||||
	$x509="0G-1G-2B-2G-3F-3E-2G-NAME-2G-3L-3L-2G-NAME-2G-3G-4F-4E-3C-1G-2F-2E-1C";
 | 
					 | 
				
			||||||
	$rsa= "0G-1B-1G-2F-2E-1D";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	%DER_i2s=(
 | 
					 | 
				
			||||||
		# SSLeay 0.4.x has this list
 | 
					 | 
				
			||||||
		"A","EOC",
 | 
					 | 
				
			||||||
		"B","INTEGER",
 | 
					 | 
				
			||||||
		"C","BIT STRING",
 | 
					 | 
				
			||||||
		"D","OCTET STRING",
 | 
					 | 
				
			||||||
		"E","NULL",
 | 
					 | 
				
			||||||
		"F","OBJECT",
 | 
					 | 
				
			||||||
		"G","SEQUENCE",
 | 
					 | 
				
			||||||
		"H","SET",
 | 
					 | 
				
			||||||
		"I","PRINTABLESTRING",
 | 
					 | 
				
			||||||
		"J","T61STRING",
 | 
					 | 
				
			||||||
		"K","IA5STRING",
 | 
					 | 
				
			||||||
		"L","UTCTIME",
 | 
					 | 
				
			||||||
		"M","NUMERICSTRING",
 | 
					 | 
				
			||||||
		"N","VIDEOTEXSTRING",
 | 
					 | 
				
			||||||
		"O","GENERALIZEDTIME",
 | 
					 | 
				
			||||||
		"P","GRAPHICSTRING",
 | 
					 | 
				
			||||||
		"Q","ISO64STRING",
 | 
					 | 
				
			||||||
		"R","GENERALSTRING",
 | 
					 | 
				
			||||||
		"S","UNIVERSALSTRING",
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		# SSLeay 0.5.x changed some things ... and I'm
 | 
					 | 
				
			||||||
		# leaving in the old stuff but adding in these
 | 
					 | 
				
			||||||
		# to handle the new as well --tjh
 | 
					 | 
				
			||||||
		# - Well I've just taken them out and added the extra new
 | 
					 | 
				
			||||||
		# ones :-) - eay
 | 
					 | 
				
			||||||
		);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	foreach (keys %DER_i2s)
 | 
					 | 
				
			||||||
		{ $DER_s2i{$DER_i2s{$_}}=$_; }
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub parse_line
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($_)=@_;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return(/\s*(\d+):d=\s*(\d+)\s+hl=\s*(\d+)\s+l=\s*(\d+|inf)\s/);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#  0:d=0 hl=4 l=377 cons: univ: SEQUENCE          
 | 
					 | 
				
			||||||
#  4:d=1 hl=2 l= 11 prim: univ: OCTET_STRING      
 | 
					 | 
				
			||||||
# 17:d=1 hl=4 l=360 cons: univ: SEQUENCE          
 | 
					 | 
				
			||||||
# 21:d=2 hl=2 l= 12 cons: univ: SEQUENCE          
 | 
					 | 
				
			||||||
# 23:d=3 hl=2 l=  8 prim: univ: OBJECT_IDENTIFIER :rc4
 | 
					 | 
				
			||||||
# 33:d=3 hl=2 l=  0 prim: univ: NULL              
 | 
					 | 
				
			||||||
# 35:d=2 hl=4 l=342 prim: univ: OCTET_STRING
 | 
					 | 
				
			||||||
sub do_private_key
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($data,@struct)=@_;
 | 
					 | 
				
			||||||
	local($file)="/tmp/b$$.DER";
 | 
					 | 
				
			||||||
	local($off,$d,$hl,$len,$_,$b,@p,$s);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	($type)=($struct[4] =~ /OBJECT_IDENTIFIER :(.*)\s*$/);
 | 
					 | 
				
			||||||
	if ($type eq "rc4")
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		($off,$d,$hl,$len)=&parse_line($struct[6]);
 | 
					 | 
				
			||||||
		open(OUT,"|$rc4_cmd >$file") ||
 | 
					 | 
				
			||||||
			die "unable to run $rc4_cmd:$!\n";
 | 
					 | 
				
			||||||
		print OUT substr($data,$off+$hl,$len);
 | 
					 | 
				
			||||||
		close(OUT);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		$b=&load_file($file);
 | 
					 | 
				
			||||||
		unlink($file);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		($s,@p)=&der_str($b);
 | 
					 | 
				
			||||||
		die "unknown rsa key type\n$s\n"
 | 
					 | 
				
			||||||
			if ($s ne '0G-1B-1G-2F-2E-1D');
 | 
					 | 
				
			||||||
		local($off,$d,$hl,$len)=&parse_line($p[5]);
 | 
					 | 
				
			||||||
		$b=substr($b,$off+$hl,$len);
 | 
					 | 
				
			||||||
		($s,@p)=&der_str($b);
 | 
					 | 
				
			||||||
		open(OUT,"|$rsa_cmd") || die "unable to run $rsa_cmd:$!\n";
 | 
					 | 
				
			||||||
		print OUT $b;
 | 
					 | 
				
			||||||
		close(OUT);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	else
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		print "'$type' is unknown\n";
 | 
					 | 
				
			||||||
		exit(1);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub do_certificate
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($data,@struct)=@_;
 | 
					 | 
				
			||||||
	local($file)="/tmp/b$$.DER";
 | 
					 | 
				
			||||||
	local($off,$d,$hl,$len,$_,$b,@p,$s);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	($off,$d,$hl,$len)=&parse_line($struct[2]);
 | 
					 | 
				
			||||||
	$b=substr($data,$off,$len+$hl);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	open(OUT,"|$x509_cmd -inform d") || die "unable to run $x509_cmd:$!\n";
 | 
					 | 
				
			||||||
	print OUT $b;
 | 
					 | 
				
			||||||
	close(OUT);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub load_file
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($file)=@_;
 | 
					 | 
				
			||||||
	local(*IN,$r,$b,$i);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	$r="";
 | 
					 | 
				
			||||||
	open(IN,"<$file") || die "unable to open $file:$!\n";
 | 
					 | 
				
			||||||
	for (;;)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		$i=sysread(IN,$b,10240);
 | 
					 | 
				
			||||||
		last if ($i <= 0);
 | 
					 | 
				
			||||||
		$r.=$b;
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	close(IN);
 | 
					 | 
				
			||||||
	return($r);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
sub load_file_parse
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	local($file)=@_;
 | 
					 | 
				
			||||||
	local(*IN,$r,@ret,$_,$i,$n,$b);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	open(IN,"$cmd -inform d -in $file|")
 | 
					 | 
				
			||||||
		|| die "unable to run der_parse\n";
 | 
					 | 
				
			||||||
	while (<IN>)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		chop;
 | 
					 | 
				
			||||||
		push(@ret,$_);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	return($r,@ret);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
							
								
								
									
										44
									
								
								apps/dgst.c
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								apps/dgst.c
									
									
									
									
									
								
							@@ -78,7 +78,7 @@ static HMAC_CTX hmac_ctx;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
					int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			||||||
	  EVP_PKEY *key, unsigned char *sigin, int siglen, const char *title,
 | 
						  EVP_PKEY *key, unsigned char *sigin, int siglen, const char *title,
 | 
				
			||||||
	  const char *file,BIO *bmd,const char *hmac_key);
 | 
						  const char *file,BIO *bmd,const char *hmac_key, int non_fips_allow);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int MAIN(int, char **);
 | 
					int MAIN(int, char **);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -103,10 +103,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	EVP_PKEY *sigkey = NULL;
 | 
						EVP_PKEY *sigkey = NULL;
 | 
				
			||||||
	unsigned char *sigbuf = NULL;
 | 
						unsigned char *sigbuf = NULL;
 | 
				
			||||||
	int siglen = 0;
 | 
						int siglen = 0;
 | 
				
			||||||
 | 
						char *passargin = NULL, *passin = NULL;
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
	char *engine=NULL;
 | 
						char *engine=NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	char *hmac_key=NULL;
 | 
						char *hmac_key=NULL;
 | 
				
			||||||
 | 
						int non_fips_allow = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -149,6 +151,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
			keyfile=*(++argv);
 | 
								keyfile=*(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							else if (!strcmp(*argv,"-passin"))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								if (--argc < 1)
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
								passargin=*++argv;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-verify") == 0)
 | 
							else if (strcmp(*argv,"-verify") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1) break;
 | 
								if (--argc < 1) break;
 | 
				
			||||||
@@ -185,6 +193,8 @@ 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,"-non-fips-allow") == 0)
 | 
				
			||||||
 | 
								non_fips_allow=1;
 | 
				
			||||||
		else if (!strcmp(*argv,"-hmac"))
 | 
							else if (!strcmp(*argv,"-hmac"))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			if (--argc < 1)
 | 
								if (--argc < 1)
 | 
				
			||||||
@@ -257,6 +267,12 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		BIO_set_callback_arg(in,bio_err);
 | 
							BIO_set_callback_arg(in,bio_err);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if(!app_passwd(bio_err, passargin, NULL, &passin, NULL))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "Error getting password\n");
 | 
				
			||||||
 | 
							goto end;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((in == NULL) || (bmd == NULL))
 | 
						if ((in == NULL) || (bmd == NULL))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
@@ -298,7 +314,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			sigkey = load_pubkey(bio_err, keyfile, keyform, 0, NULL,
 | 
								sigkey = load_pubkey(bio_err, keyfile, keyform, 0, NULL,
 | 
				
			||||||
				e, "key file");
 | 
									e, "key file");
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			sigkey = load_key(bio_err, keyfile, keyform, 0, NULL,
 | 
								sigkey = load_key(bio_err, keyfile, keyform, 0, passin,
 | 
				
			||||||
				e, "key file");
 | 
									e, "key file");
 | 
				
			||||||
		if (!sigkey)
 | 
							if (!sigkey)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -329,10 +345,18 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (non_fips_allow)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							EVP_MD_CTX *md_ctx;
 | 
				
			||||||
 | 
							BIO_get_md_ctx(bmd,&md_ctx);
 | 
				
			||||||
 | 
							EVP_MD_CTX_set_flags(md_ctx, EVP_MD_CTX_FLAG_NON_FIPS_ALLOW);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* we use md as a filter, reading from 'in' */
 | 
						/* we use md as a filter, reading from 'in' */
 | 
				
			||||||
	if (!BIO_set_md(bmd,md))
 | 
						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",
 | 
				
			||||||
 | 
												EVP_MD_name(md));
 | 
				
			||||||
		ERR_print_errors(bio_err);
 | 
							ERR_print_errors(bio_err);
 | 
				
			||||||
		goto end;
 | 
							goto end;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -343,7 +367,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
							BIO_set_fp(in,stdin,BIO_NOCLOSE);
 | 
				
			||||||
		err=do_fp(out, buf,inp,separator, out_bin, sigkey, sigbuf,
 | 
							err=do_fp(out, buf,inp,separator, out_bin, sigkey, sigbuf,
 | 
				
			||||||
			  siglen,"","(stdin)",bmd,hmac_key);
 | 
								  siglen,"","(stdin)",bmd,hmac_key, non_fips_allow);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
@@ -369,7 +393,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			else
 | 
								else
 | 
				
			||||||
				tmp="";
 | 
									tmp="";
 | 
				
			||||||
			r=do_fp(out,buf,inp,separator,out_bin,sigkey,sigbuf,
 | 
								r=do_fp(out,buf,inp,separator,out_bin,sigkey,sigbuf,
 | 
				
			||||||
				siglen,tmp,argv[i],bmd,hmac_key);
 | 
									siglen,tmp,argv[i],bmd,hmac_key,non_fips_allow);
 | 
				
			||||||
			if(r)
 | 
								if(r)
 | 
				
			||||||
			    err=r;
 | 
								    err=r;
 | 
				
			||||||
			if(tofree)
 | 
								if(tofree)
 | 
				
			||||||
@@ -384,6 +408,8 @@ end:
 | 
				
			|||||||
		OPENSSL_free(buf);
 | 
							OPENSSL_free(buf);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	if (in != NULL) BIO_free(in);
 | 
						if (in != NULL) BIO_free(in);
 | 
				
			||||||
 | 
						if (passin)
 | 
				
			||||||
 | 
							OPENSSL_free(passin);
 | 
				
			||||||
	BIO_free_all(out);
 | 
						BIO_free_all(out);
 | 
				
			||||||
	EVP_PKEY_free(sigkey);
 | 
						EVP_PKEY_free(sigkey);
 | 
				
			||||||
	if(sigbuf) OPENSSL_free(sigbuf);
 | 
						if(sigbuf) OPENSSL_free(sigbuf);
 | 
				
			||||||
@@ -394,7 +420,7 @@ end:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
					int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			||||||
	  EVP_PKEY *key, unsigned char *sigin, int siglen, const char *title,
 | 
						  EVP_PKEY *key, unsigned char *sigin, int siglen, const char *title,
 | 
				
			||||||
	  const char *file,BIO *bmd,const char *hmac_key)
 | 
						  const char *file,BIO *bmd,const char *hmac_key, int non_fips_allow)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	unsigned int len;
 | 
						unsigned int len;
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
@@ -405,7 +431,11 @@ int do_fp(BIO *out, unsigned char *buf, BIO *bp, int sep, int binout,
 | 
				
			|||||||
		EVP_MD *md;
 | 
							EVP_MD *md;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		BIO_get_md(bmd,&md);
 | 
							BIO_get_md(bmd,&md);
 | 
				
			||||||
		HMAC_Init(&hmac_ctx,hmac_key,strlen(hmac_key),md);
 | 
							HMAC_CTX_init(&hmac_ctx);
 | 
				
			||||||
 | 
							if (non_fips_allow)
 | 
				
			||||||
 | 
								HMAC_CTX_set_flags(&hmac_ctx,
 | 
				
			||||||
 | 
										EVP_MD_CTX_FLAG_NON_FIPS_ALLOW);
 | 
				
			||||||
 | 
							HMAC_Init_ex(&hmac_ctx,hmac_key,strlen(hmac_key),md, NULL);
 | 
				
			||||||
		BIO_get_md_ctx(bmd,&md_ctx);
 | 
							BIO_get_md_ctx(bmd,&md_ctx);
 | 
				
			||||||
		BIO_set_md_ctx(bmd,&hmac_ctx.md_ctx);
 | 
							BIO_set_md_ctx(bmd,&hmac_ctx.md_ctx);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										44
									
								
								apps/enc.c
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								apps/enc.c
									
									
									
									
									
								
							@@ -118,6 +118,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	int enc=1,printkey=0,i,base64=0;
 | 
						int enc=1,printkey=0,i,base64=0;
 | 
				
			||||||
	int debug=0,olb64=0,nosalt=0;
 | 
						int debug=0,olb64=0,nosalt=0;
 | 
				
			||||||
	const EVP_CIPHER *cipher=NULL,*c;
 | 
						const EVP_CIPHER *cipher=NULL,*c;
 | 
				
			||||||
 | 
						EVP_CIPHER_CTX *ctx = NULL;
 | 
				
			||||||
	char *inf=NULL,*outf=NULL;
 | 
						char *inf=NULL,*outf=NULL;
 | 
				
			||||||
	BIO *in=NULL,*out=NULL,*b64=NULL,*benc=NULL,*rbio=NULL,*wbio=NULL;
 | 
						BIO *in=NULL,*out=NULL,*b64=NULL,*benc=NULL,*rbio=NULL,*wbio=NULL;
 | 
				
			||||||
#define PROG_NAME_SIZE  39
 | 
					#define PROG_NAME_SIZE  39
 | 
				
			||||||
@@ -126,6 +127,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *engine = NULL;
 | 
						char *engine = NULL;
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	const EVP_MD *dgst=NULL;
 | 
						const EVP_MD *dgst=NULL;
 | 
				
			||||||
 | 
						int non_fips_allow = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	apps_startup();
 | 
						apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -260,6 +262,8 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			if (--argc < 1) goto bad;
 | 
								if (--argc < 1) goto bad;
 | 
				
			||||||
			md= *(++argv);
 | 
								md= *(++argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-non-fips-allow") == 0)
 | 
				
			||||||
 | 
								non_fips_allow = 1;
 | 
				
			||||||
		else if	((argv[0][0] == '-') &&
 | 
							else if	((argv[0][0] == '-') &&
 | 
				
			||||||
			((c=EVP_get_cipherbyname(&(argv[0][1]))) != NULL))
 | 
								((c=EVP_get_cipherbyname(&(argv[0][1]))) != NULL))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -539,13 +543,43 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if ((benc=BIO_new(BIO_f_cipher())) == NULL)
 | 
							if ((benc=BIO_new(BIO_f_cipher())) == NULL)
 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
		BIO_set_cipher(benc,cipher,key,iv,enc);
 | 
					
 | 
				
			||||||
		if (nopad)
 | 
							/* Since we may be changing parameters work on the encryption
 | 
				
			||||||
 | 
							 * context rather than calling BIO_set_cipher().
 | 
				
			||||||
 | 
							 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							BIO_get_cipher_ctx(benc, &ctx);
 | 
				
			||||||
 | 
							if (!EVP_CipherInit_ex(ctx, cipher, NULL, NULL, NULL, enc))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			EVP_CIPHER_CTX *ctx;
 | 
								BIO_printf(bio_err, "Error setting cipher %s\n",
 | 
				
			||||||
			BIO_get_cipher_ctx(benc, &ctx);
 | 
										EVP_CIPHER_name(cipher));
 | 
				
			||||||
			EVP_CIPHER_CTX_set_padding(ctx, 0);
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (non_fips_allow)
 | 
				
			||||||
 | 
								EVP_CIPHER_CTX_set_flags(ctx,
 | 
				
			||||||
 | 
									EVP_CIPH_FLAG_NON_FIPS_ALLOW);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (!EVP_CipherInit_ex(ctx, NULL, NULL, key, iv, enc))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "Error setting cipher %s\n",
 | 
				
			||||||
 | 
										EVP_CIPHER_name(cipher));
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (nopad)
 | 
				
			||||||
 | 
								EVP_CIPHER_CTX_set_padding(ctx, 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (!EVP_CipherInit_ex(ctx, NULL, NULL, key, iv, enc))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								BIO_printf(bio_err, "Error setting cipher %s\n",
 | 
				
			||||||
 | 
										EVP_CIPHER_name(cipher));
 | 
				
			||||||
 | 
								ERR_print_errors(bio_err);
 | 
				
			||||||
 | 
								goto end;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (debug)
 | 
							if (debug)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_set_callback(benc,BIO_debug_callback);
 | 
								BIO_set_callback(benc,BIO_debug_callback);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -387,11 +387,15 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if (strcmp(*argv,"-pre") == 0)
 | 
							else if (strcmp(*argv,"-pre") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--; argv++;
 | 
								argc--; argv++;
 | 
				
			||||||
 | 
								if (argc == 0)
 | 
				
			||||||
 | 
									goto skip_arg_loop;
 | 
				
			||||||
			sk_push(pre_cmds,*argv);
 | 
								sk_push(pre_cmds,*argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if (strcmp(*argv,"-post") == 0)
 | 
							else if (strcmp(*argv,"-post") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			argc--; argv++;
 | 
								argc--; argv++;
 | 
				
			||||||
 | 
								if (argc == 0)
 | 
				
			||||||
 | 
									goto skip_arg_loop;
 | 
				
			||||||
			sk_push(post_cmds,*argv);
 | 
								sk_push(post_cmds,*argv);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		else if ((strncmp(*argv,"-h",2) == 0) ||
 | 
							else if ((strncmp(*argv,"-h",2) == 0) ||
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -88,6 +88,9 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	RSA *rsa=NULL;
 | 
						RSA *rsa=NULL;
 | 
				
			||||||
	int i,num=DEFBITS;
 | 
						int i,num=DEFBITS;
 | 
				
			||||||
	long l;
 | 
						long l;
 | 
				
			||||||
 | 
					#ifdef OPENSSL_FIPS
 | 
				
			||||||
 | 
						int use_x931 = 0;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	const EVP_CIPHER *enc=NULL;
 | 
						const EVP_CIPHER *enc=NULL;
 | 
				
			||||||
	unsigned long f4=RSA_F4;
 | 
						unsigned long f4=RSA_F4;
 | 
				
			||||||
	char *outfile=NULL;
 | 
						char *outfile=NULL;
 | 
				
			||||||
@@ -126,6 +129,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			f4=3;
 | 
								f4=3;
 | 
				
			||||||
		else if (strcmp(*argv,"-F4") == 0 || strcmp(*argv,"-f4") == 0)
 | 
							else if (strcmp(*argv,"-F4") == 0 || strcmp(*argv,"-f4") == 0)
 | 
				
			||||||
			f4=RSA_F4;
 | 
								f4=RSA_F4;
 | 
				
			||||||
 | 
					#ifdef OPENSSL_FIPS
 | 
				
			||||||
 | 
							else if (strcmp(*argv,"-x931") == 0)
 | 
				
			||||||
 | 
								use_x931 = 1;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
#ifndef OPENSSL_NO_ENGINE
 | 
					#ifndef OPENSSL_NO_ENGINE
 | 
				
			||||||
		else if (strcmp(*argv,"-engine") == 0)
 | 
							else if (strcmp(*argv,"-engine") == 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
@@ -233,11 +240,27 @@ 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);
 | 
				
			||||||
	rsa=RSA_generate_key(num,f4,genrsa_cb,bio_err);
 | 
					#ifdef OPENSSL_FIPS
 | 
				
			||||||
 | 
						if (use_x931)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIGNUM *pubexp;
 | 
				
			||||||
 | 
							pubexp = BN_new();
 | 
				
			||||||
 | 
							BN_set_word(pubexp, f4);
 | 
				
			||||||
 | 
							rsa = RSA_X931_generate_key(num, pubexp, genrsa_cb, bio_err);
 | 
				
			||||||
 | 
							BN_free(pubexp);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							rsa=RSA_generate_key(num,f4,genrsa_cb,bio_err);
 | 
				
			||||||
		
 | 
							
 | 
				
			||||||
	app_RAND_write_file(NULL, bio_err);
 | 
						app_RAND_write_file(NULL, bio_err);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (rsa == NULL) goto err;
 | 
						if (rsa == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							BIO_printf(bio_err, "Key Generation error\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							goto err;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	/* We need to do the following for when the base number size is <
 | 
						/* We need to do the following for when the base number size is <
 | 
				
			||||||
	 * long, esp windows 3.1 :-(. */
 | 
						 * long, esp windows 3.1 :-(. */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -650,7 +650,7 @@ $ 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"
 | 
					$ 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
 | 
				
			||||||
$!
 | 
					$!
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -258,3 +258,56 @@ basicConstraints = CA:true
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
authorityKeyIdentifier=keyid:always,issuer:always
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[ proxy_cert_ext ]
 | 
				
			||||||
 | 
					# These extensions should be added when creating a proxy certificate
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This goes against PKIX guidelines but some CAs do it and some software
 | 
				
			||||||
 | 
					# requires this to avoid interpreting an end user certificate as a CA.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					basicConstraints=CA:FALSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Here are some examples of the usage of nsCertType. If it is omitted
 | 
				
			||||||
 | 
					# the certificate can be used for anything *except* object signing.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This is OK for an SSL server.
 | 
				
			||||||
 | 
					# nsCertType			= server
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# For an object signing certificate this would be used.
 | 
				
			||||||
 | 
					# nsCertType = objsign
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# For normal client use this is typical
 | 
				
			||||||
 | 
					# nsCertType = client, email
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# and for everything including object signing:
 | 
				
			||||||
 | 
					# nsCertType = client, email, objsign
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This is typical in keyUsage for a client certificate.
 | 
				
			||||||
 | 
					# keyUsage = nonRepudiation, digitalSignature, keyEncipherment
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This will be displayed in Netscape's comment listbox.
 | 
				
			||||||
 | 
					nsComment			= "OpenSSL Generated Certificate"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# PKIX recommendations harmless if included in all certificates.
 | 
				
			||||||
 | 
					subjectKeyIdentifier=hash
 | 
				
			||||||
 | 
					authorityKeyIdentifier=keyid,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This stuff is for subjectAltName and issuerAltname.
 | 
				
			||||||
 | 
					# Import the email address.
 | 
				
			||||||
 | 
					# subjectAltName=email:copy
 | 
				
			||||||
 | 
					# An alternative to produce certificates that aren't
 | 
				
			||||||
 | 
					# deprecated according to PKIX.
 | 
				
			||||||
 | 
					# subjectAltName=email:move
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copy subject details
 | 
				
			||||||
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#nsCaRevocationUrl		= http://www.domain.dom/ca-crl.pem
 | 
				
			||||||
 | 
					#nsBaseUrl
 | 
				
			||||||
 | 
					#nsRevocationUrl
 | 
				
			||||||
 | 
					#nsRenewalUrl
 | 
				
			||||||
 | 
					#nsCaPolicyUrl
 | 
				
			||||||
 | 
					#nsSslServerName
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This really needs to be in place for it to be a proxy certificate.
 | 
				
			||||||
 | 
					proxyCertInfo=critical,language:id-ppl-anyLanguage,pathlen:3,policy:foo
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -239,7 +239,7 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
	if(getenv("OPENSSL_FIPS")) {
 | 
						if(getenv("OPENSSL_FIPS")) {
 | 
				
			||||||
#if defined(_WIN32)
 | 
					#if defined(_WIN32)
 | 
				
			||||||
		char filename[MAX_PATH] = "";
 | 
							char filename[MAX_PATH] = "";
 | 
				
			||||||
		GetModuleFileName( NULL, filename, MAX_PATH) ;
 | 
							GetModuleFileNameA( NULL, filename, MAX_PATH) ;
 | 
				
			||||||
		p = filename;
 | 
							p = filename;
 | 
				
			||||||
#else
 | 
					#else
 | 
				
			||||||
		p = Argv[0];
 | 
							p = Argv[0];
 | 
				
			||||||
@@ -247,11 +247,9 @@ int main(int Argc, char *Argv[])
 | 
				
			|||||||
		if (!FIPS_mode_set(1,p)) {
 | 
							if (!FIPS_mode_set(1,p)) {
 | 
				
			||||||
			ERR_load_crypto_strings();
 | 
								ERR_load_crypto_strings();
 | 
				
			||||||
			ERR_print_errors(BIO_new_fp(stderr,BIO_NOCLOSE));
 | 
								ERR_print_errors(BIO_new_fp(stderr,BIO_NOCLOSE));
 | 
				
			||||||
			exit(1);
 | 
								EXIT(1);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		in_FIPS_mode = 1;
 | 
							in_FIPS_mode = 1;
 | 
				
			||||||
		if (getenv("OPENSSL_FIPS_MD5"))
 | 
					 | 
				
			||||||
			FIPS_allow_md5(1);
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	if (bio_err == NULL)
 | 
						if (bio_err == NULL)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -258,3 +258,56 @@ basicConstraints = CA:true
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# issuerAltName=issuer:copy
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
authorityKeyIdentifier=keyid:always,issuer:always
 | 
					authorityKeyIdentifier=keyid:always,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					[ proxy_cert_ext ]
 | 
				
			||||||
 | 
					# These extensions should be added when creating a proxy certificate
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This goes against PKIX guidelines but some CAs do it and some software
 | 
				
			||||||
 | 
					# requires this to avoid interpreting an end user certificate as a CA.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					basicConstraints=CA:FALSE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Here are some examples of the usage of nsCertType. If it is omitted
 | 
				
			||||||
 | 
					# the certificate can be used for anything *except* object signing.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This is OK for an SSL server.
 | 
				
			||||||
 | 
					# nsCertType			= server
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# For an object signing certificate this would be used.
 | 
				
			||||||
 | 
					# nsCertType = objsign
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# For normal client use this is typical
 | 
				
			||||||
 | 
					# nsCertType = client, email
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# and for everything including object signing:
 | 
				
			||||||
 | 
					# nsCertType = client, email, objsign
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This is typical in keyUsage for a client certificate.
 | 
				
			||||||
 | 
					# keyUsage = nonRepudiation, digitalSignature, keyEncipherment
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This will be displayed in Netscape's comment listbox.
 | 
				
			||||||
 | 
					nsComment			= "OpenSSL Generated Certificate"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# PKIX recommendations harmless if included in all certificates.
 | 
				
			||||||
 | 
					subjectKeyIdentifier=hash
 | 
				
			||||||
 | 
					authorityKeyIdentifier=keyid,issuer:always
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This stuff is for subjectAltName and issuerAltname.
 | 
				
			||||||
 | 
					# Import the email address.
 | 
				
			||||||
 | 
					# subjectAltName=email:copy
 | 
				
			||||||
 | 
					# An alternative to produce certificates that aren't
 | 
				
			||||||
 | 
					# deprecated according to PKIX.
 | 
				
			||||||
 | 
					# subjectAltName=email:move
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copy subject details
 | 
				
			||||||
 | 
					# issuerAltName=issuer:copy
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#nsCaRevocationUrl		= http://www.domain.dom/ca-crl.pem
 | 
				
			||||||
 | 
					#nsBaseUrl
 | 
				
			||||||
 | 
					#nsRevocationUrl
 | 
				
			||||||
 | 
					#nsRenewalUrl
 | 
				
			||||||
 | 
					#nsCaPolicyUrl
 | 
				
			||||||
 | 
					#nsSslServerName
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# This really needs to be in place for it to be a proxy certificate.
 | 
				
			||||||
 | 
					proxyCertInfo=critical,language:id-ppl-anyLanguage,pathlen:3,policy:foo
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -109,7 +109,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    int maciter = PKCS12_DEFAULT_ITER;
 | 
					    int maciter = PKCS12_DEFAULT_ITER;
 | 
				
			||||||
    int twopass = 0;
 | 
					    int twopass = 0;
 | 
				
			||||||
    int keytype = 0;
 | 
					    int keytype = 0;
 | 
				
			||||||
    int cert_pbe = NID_pbe_WithSHA1And40BitRC2_CBC;
 | 
					    int cert_pbe;
 | 
				
			||||||
    int key_pbe = NID_pbe_WithSHA1And3_Key_TripleDES_CBC;
 | 
					    int key_pbe = NID_pbe_WithSHA1And3_Key_TripleDES_CBC;
 | 
				
			||||||
    int ret = 1;
 | 
					    int ret = 1;
 | 
				
			||||||
    int macver = 1;
 | 
					    int macver = 1;
 | 
				
			||||||
@@ -126,6 +126,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    apps_startup();
 | 
					    apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef OPENSSL_FIPS
 | 
				
			||||||
 | 
					    if (FIPS_mode())
 | 
				
			||||||
 | 
						cert_pbe = NID_pbe_WithSHA1And3_Key_TripleDES_CBC;
 | 
				
			||||||
 | 
					    else
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					    cert_pbe = NID_pbe_WithSHA1And40BitRC2_CBC;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    enc = EVP_des_ede3_cbc();
 | 
					    enc = EVP_des_ede3_cbc();
 | 
				
			||||||
    if (bio_err == NULL ) bio_err = BIO_new_fp (stderr, BIO_NOCLOSE);
 | 
					    if (bio_err == NULL ) bio_err = BIO_new_fp (stderr, BIO_NOCLOSE);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -666,7 +673,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    CRYPTO_push_info("verify MAC");
 | 
					    CRYPTO_push_info("verify MAC");
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
	/* If we enter empty password try no password first */
 | 
						/* If we enter empty password try no password first */
 | 
				
			||||||
	if(!macpass[0] && PKCS12_verify_mac(p12, NULL, 0)) {
 | 
						if(!mpass[0] && PKCS12_verify_mac(p12, NULL, 0)) {
 | 
				
			||||||
		/* If mac and crypto pass the same set it to NULL too */
 | 
							/* If mac and crypto pass the same set it to NULL too */
 | 
				
			||||||
		if(!twopass) cpass = NULL;
 | 
							if(!twopass) cpass = NULL;
 | 
				
			||||||
	} else if (!PKCS12_verify_mac(p12, mpass, -1)) {
 | 
						} else if (!PKCS12_verify_mac(p12, mpass, -1)) {
 | 
				
			||||||
@@ -710,9 +717,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
int dump_certs_keys_p12 (BIO *out, PKCS12 *p12, char *pass,
 | 
					int dump_certs_keys_p12 (BIO *out, PKCS12 *p12, char *pass,
 | 
				
			||||||
	     int passlen, int options, char *pempass)
 | 
						     int passlen, int options, char *pempass)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	STACK_OF(PKCS7) *asafes;
 | 
						STACK_OF(PKCS7) *asafes = NULL;
 | 
				
			||||||
	STACK_OF(PKCS12_SAFEBAG) *bags;
 | 
						STACK_OF(PKCS12_SAFEBAG) *bags;
 | 
				
			||||||
	int i, bagnid;
 | 
						int i, bagnid;
 | 
				
			||||||
 | 
						int ret = 0;
 | 
				
			||||||
	PKCS7 *p7;
 | 
						PKCS7 *p7;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!( asafes = PKCS12_unpack_authsafes(p12))) return 0;
 | 
						if (!( asafes = PKCS12_unpack_authsafes(p12))) return 0;
 | 
				
			||||||
@@ -730,16 +738,22 @@ int dump_certs_keys_p12 (BIO *out, PKCS12 *p12, char *pass,
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
			bags = PKCS12_unpack_p7encdata(p7, pass, passlen);
 | 
								bags = PKCS12_unpack_p7encdata(p7, pass, passlen);
 | 
				
			||||||
		} else continue;
 | 
							} else continue;
 | 
				
			||||||
		if (!bags) return 0;
 | 
							if (!bags) goto err;
 | 
				
			||||||
	    	if (!dump_certs_pkeys_bags (out, bags, pass, passlen, 
 | 
						    	if (!dump_certs_pkeys_bags (out, bags, pass, passlen, 
 | 
				
			||||||
						 options, pempass)) {
 | 
											 options, pempass)) {
 | 
				
			||||||
			sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
								sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
				
			||||||
			return 0;
 | 
								goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
							sk_PKCS12_SAFEBAG_pop_free (bags, PKCS12_SAFEBAG_free);
 | 
				
			||||||
 | 
							bags = NULL;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	sk_PKCS7_pop_free (asafes, PKCS7_free);
 | 
						ret = 1;
 | 
				
			||||||
	return 1;
 | 
					
 | 
				
			||||||
 | 
						err:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (asafes)
 | 
				
			||||||
 | 
							sk_PKCS7_pop_free (asafes, PKCS7_free);
 | 
				
			||||||
 | 
						return ret;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int dump_certs_pkeys_bags (BIO *out, STACK_OF(PKCS12_SAFEBAG) *bags,
 | 
					int dump_certs_pkeys_bags (BIO *out, STACK_OF(PKCS12_SAFEBAG) *bags,
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										46
									
								
								apps/prime.c
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								apps/prime.c
									
									
									
									
									
								
							@@ -61,7 +61,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    int hex=0;
 | 
					    int hex=0;
 | 
				
			||||||
    int checks=20;
 | 
					    int checks=20;
 | 
				
			||||||
    BIGNUM *bn=NULL;
 | 
					    BIGNUM *bn=NULL;
 | 
				
			||||||
    BIO *bio_out=NULL;
 | 
					    BIO *bio_out;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    apps_startup();
 | 
					    apps_startup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -69,18 +69,6 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
						if ((bio_err=BIO_new(BIO_s_file())) != NULL)
 | 
				
			||||||
	    BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
						    BIO_set_fp(bio_err,stderr,BIO_NOCLOSE|BIO_FP_TEXT);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (bio_out == NULL)
 | 
					 | 
				
			||||||
	if ((bio_out=BIO_new(BIO_s_file())) != NULL)
 | 
					 | 
				
			||||||
	    {
 | 
					 | 
				
			||||||
	    BIO_set_fp(bio_out,stdout,BIO_NOCLOSE);
 | 
					 | 
				
			||||||
#ifdef OPENSSL_SYS_VMS
 | 
					 | 
				
			||||||
	    {
 | 
					 | 
				
			||||||
	    BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
					 | 
				
			||||||
	    bio_out = BIO_push(tmpbio, bio_out);
 | 
					 | 
				
			||||||
	    }
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
	    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    --argc;
 | 
					    --argc;
 | 
				
			||||||
    ++argv;
 | 
					    ++argv;
 | 
				
			||||||
    while (argc >= 1 && **argv == '-')
 | 
					    while (argc >= 1 && **argv == '-')
 | 
				
			||||||
@@ -95,16 +83,29 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
	    {
 | 
						    {
 | 
				
			||||||
	    BIO_printf(bio_err,"Unknown option '%s'\n",*argv);
 | 
						    BIO_printf(bio_err,"Unknown option '%s'\n",*argv);
 | 
				
			||||||
	bad:
 | 
						    goto bad;
 | 
				
			||||||
	    BIO_printf(bio_err,"options are\n");
 | 
					 | 
				
			||||||
	    BIO_printf(bio_err,"%-14s hex\n","-hex");
 | 
					 | 
				
			||||||
	    BIO_printf(bio_err,"%-14s number of checks\n","-checks <n>");
 | 
					 | 
				
			||||||
	    exit(1);
 | 
					 | 
				
			||||||
	    }
 | 
						    }
 | 
				
			||||||
	--argc;
 | 
						--argc;
 | 
				
			||||||
	++argv;
 | 
						++argv;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (argv[0] == NULL)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						BIO_printf(bio_err,"No prime specified\n");
 | 
				
			||||||
 | 
						goto bad;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					   if ((bio_out=BIO_new(BIO_s_file())) != NULL)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						BIO_set_fp(bio_out,stdout,BIO_NOCLOSE);
 | 
				
			||||||
 | 
					#ifdef OPENSSL_SYS_VMS
 | 
				
			||||||
 | 
						    {
 | 
				
			||||||
 | 
						    BIO *tmpbio = BIO_new(BIO_f_linebuffer());
 | 
				
			||||||
 | 
						    bio_out = BIO_push(tmpbio, bio_out);
 | 
				
			||||||
 | 
						    }
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if(hex)
 | 
					    if(hex)
 | 
				
			||||||
	BN_hex2bn(&bn,argv[0]);
 | 
						BN_hex2bn(&bn,argv[0]);
 | 
				
			||||||
    else
 | 
					    else
 | 
				
			||||||
@@ -114,5 +115,14 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
    BIO_printf(bio_out," is %sprime\n",
 | 
					    BIO_printf(bio_out," is %sprime\n",
 | 
				
			||||||
	       BN_is_prime(bn,checks,NULL,NULL,NULL) ? "" : "not ");
 | 
						       BN_is_prime(bn,checks,NULL,NULL,NULL) ? "" : "not ");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    BN_free(bn);
 | 
				
			||||||
 | 
					    BIO_free_all(bio_out);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return 0;
 | 
					    return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    bad:
 | 
				
			||||||
 | 
					    BIO_printf(bio_err,"options are\n");
 | 
				
			||||||
 | 
					    BIO_printf(bio_err,"%-14s hex\n","-hex");
 | 
				
			||||||
 | 
					    BIO_printf(bio_err,"%-14s number of checks\n","-checks <n>");
 | 
				
			||||||
 | 
					    return 1;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										20
									
								
								apps/req.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								apps/req.c
									
									
									
									
									
								
							@@ -175,7 +175,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	char *passin = NULL, *passout = NULL;
 | 
						char *passin = NULL, *passout = NULL;
 | 
				
			||||||
	char *p;
 | 
						char *p;
 | 
				
			||||||
	char *subj = NULL;
 | 
						char *subj = NULL;
 | 
				
			||||||
	const EVP_MD *md_alg=NULL,*digest=EVP_md5();
 | 
						const EVP_MD *md_alg=NULL,*digest;
 | 
				
			||||||
	unsigned long chtype = MBSTRING_ASC;
 | 
						unsigned long chtype = MBSTRING_ASC;
 | 
				
			||||||
#ifndef MONOLITH
 | 
					#ifndef MONOLITH
 | 
				
			||||||
	char *to_free;
 | 
						char *to_free;
 | 
				
			||||||
@@ -197,6 +197,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	informat=FORMAT_PEM;
 | 
						informat=FORMAT_PEM;
 | 
				
			||||||
	outformat=FORMAT_PEM;
 | 
						outformat=FORMAT_PEM;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef  OPENSSL_FIPS
 | 
				
			||||||
 | 
						if (FIPS_mode())
 | 
				
			||||||
 | 
							digest = EVP_sha1();
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							digest = EVP_md5();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	prog=argv[0];
 | 
						prog=argv[0];
 | 
				
			||||||
	argc--;
 | 
						argc--;
 | 
				
			||||||
	argv++;
 | 
						argv++;
 | 
				
			||||||
@@ -499,13 +506,16 @@ bad:
 | 
				
			|||||||
	else
 | 
						else
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		req_conf=config;
 | 
							req_conf=config;
 | 
				
			||||||
		if( verbose )
 | 
					
 | 
				
			||||||
			BIO_printf(bio_err,"Using configuration from %s\n",
 | 
					 | 
				
			||||||
			default_config_file);
 | 
					 | 
				
			||||||
		if (req_conf == NULL)
 | 
							if (req_conf == NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(bio_err,"Unable to load config info\n");
 | 
								BIO_printf(bio_err,"Unable to load config info from %s\n", default_config_file);
 | 
				
			||||||
 | 
								if (newreq)
 | 
				
			||||||
 | 
									goto end;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							else if( verbose )
 | 
				
			||||||
 | 
								BIO_printf(bio_err,"Using configuration from %s\n",
 | 
				
			||||||
 | 
								default_config_file);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (req_conf != NULL)
 | 
						if (req_conf != NULL)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,7 +3,7 @@
 | 
				
			|||||||
 * project 2000.
 | 
					 * project 2000.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 2000 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 2000-2005 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
 | 
				
			||||||
@@ -147,6 +147,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
		else if(!strcmp(*argv, "-oaep")) pad = RSA_PKCS1_OAEP_PADDING;
 | 
							else if(!strcmp(*argv, "-oaep")) pad = RSA_PKCS1_OAEP_PADDING;
 | 
				
			||||||
		else if(!strcmp(*argv, "-ssl")) pad = RSA_SSLV23_PADDING;
 | 
							else if(!strcmp(*argv, "-ssl")) pad = RSA_SSLV23_PADDING;
 | 
				
			||||||
		else if(!strcmp(*argv, "-pkcs")) pad = RSA_PKCS1_PADDING;
 | 
							else if(!strcmp(*argv, "-pkcs")) pad = RSA_PKCS1_PADDING;
 | 
				
			||||||
 | 
							else if(!strcmp(*argv, "-x931")) pad = RSA_X931_PADDING;
 | 
				
			||||||
		else if(!strcmp(*argv, "-sign")) {
 | 
							else if(!strcmp(*argv, "-sign")) {
 | 
				
			||||||
			rsa_mode = RSA_SIGN;
 | 
								rsa_mode = RSA_SIGN;
 | 
				
			||||||
			need_priv = 1;
 | 
								need_priv = 1;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -197,6 +197,9 @@ static void sc_usage(void)
 | 
				
			|||||||
	BIO_printf(bio_err," -pause        - sleep(1) after each read(2) and write(2) system call\n");
 | 
						BIO_printf(bio_err," -pause        - sleep(1) after each read(2) and write(2) system call\n");
 | 
				
			||||||
	BIO_printf(bio_err," -showcerts    - show all certificates in the chain\n");
 | 
						BIO_printf(bio_err," -showcerts    - show all certificates in the chain\n");
 | 
				
			||||||
	BIO_printf(bio_err," -debug        - extra output\n");
 | 
						BIO_printf(bio_err," -debug        - extra output\n");
 | 
				
			||||||
 | 
					#ifdef WATT32
 | 
				
			||||||
 | 
						BIO_printf(bio_err," -wdebug       - WATT-32 tcp debugging\n");
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
	BIO_printf(bio_err," -msg          - Show protocol messages\n");
 | 
						BIO_printf(bio_err," -msg          - Show protocol messages\n");
 | 
				
			||||||
	BIO_printf(bio_err," -nbio_test    - more ssl protocol testing\n");
 | 
						BIO_printf(bio_err," -nbio_test    - more ssl protocol testing\n");
 | 
				
			||||||
	BIO_printf(bio_err," -state        - print the 'ssl' states\n");
 | 
						BIO_printf(bio_err," -state        - print the 'ssl' states\n");
 | 
				
			||||||
@@ -348,6 +351,10 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
			c_Pause=1;
 | 
								c_Pause=1;
 | 
				
			||||||
		else if	(strcmp(*argv,"-debug") == 0)
 | 
							else if	(strcmp(*argv,"-debug") == 0)
 | 
				
			||||||
			c_debug=1;
 | 
								c_debug=1;
 | 
				
			||||||
 | 
					#ifdef WATT32
 | 
				
			||||||
 | 
							else if	(strcmp(*argv,"-wdebug") == 0)
 | 
				
			||||||
 | 
								dbug_init();
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		else if	(strcmp(*argv,"-msg") == 0)
 | 
							else if	(strcmp(*argv,"-msg") == 0)
 | 
				
			||||||
			c_msg=1;
 | 
								c_msg=1;
 | 
				
			||||||
		else if	(strcmp(*argv,"-showcerts") == 0)
 | 
							else if	(strcmp(*argv,"-showcerts") == 0)
 | 
				
			||||||
@@ -588,6 +595,8 @@ re_start:
 | 
				
			|||||||
	if (starttls_proto == 1)
 | 
						if (starttls_proto == 1)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		BIO_read(sbio,mbuf,BUFSIZZ);
 | 
							BIO_read(sbio,mbuf,BUFSIZZ);
 | 
				
			||||||
 | 
							BIO_printf(sbio,"EHLO some.host.name\r\n");
 | 
				
			||||||
 | 
							BIO_read(sbio,mbuf,BUFSIZZ);
 | 
				
			||||||
		BIO_printf(sbio,"STARTTLS\r\n");
 | 
							BIO_printf(sbio,"STARTTLS\r\n");
 | 
				
			||||||
		BIO_read(sbio,sbuf,BUFSIZZ);
 | 
							BIO_read(sbio,sbuf,BUFSIZZ);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -153,7 +153,6 @@ static int ssl_sock_init(void)
 | 
				
			|||||||
#ifdef WATT32
 | 
					#ifdef WATT32
 | 
				
			||||||
	extern int _watt_do_exit;
 | 
						extern int _watt_do_exit;
 | 
				
			||||||
	_watt_do_exit = 0;
 | 
						_watt_do_exit = 0;
 | 
				
			||||||
	dbug_init();
 | 
					 | 
				
			||||||
	if (sock_init())
 | 
						if (sock_init())
 | 
				
			||||||
		return (0);
 | 
							return (0);
 | 
				
			||||||
#elif defined(OPENSSL_SYS_WINDOWS)
 | 
					#elif defined(OPENSSL_SYS_WINDOWS)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1706,7 +1706,7 @@ show_res:
 | 
				
			|||||||
				k,rsa_bits[k],rsa_results[k][0],
 | 
									k,rsa_bits[k],rsa_results[k][0],
 | 
				
			||||||
				rsa_results[k][1]);
 | 
									rsa_results[k][1]);
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			fprintf(stdout,"rsa %4u bits %8.4fs %8.4fs %8.1f %8.1f\n",
 | 
								fprintf(stdout,"rsa %4u bits %8.6fs %8.6fs %8.1f %8.1f\n",
 | 
				
			||||||
				rsa_bits[k],rsa_results[k][0],rsa_results[k][1],
 | 
									rsa_bits[k],rsa_results[k][0],rsa_results[k][1],
 | 
				
			||||||
				1.0/rsa_results[k][0],1.0/rsa_results[k][1]);
 | 
									1.0/rsa_results[k][0],1.0/rsa_results[k][1]);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -1725,7 +1725,7 @@ show_res:
 | 
				
			|||||||
			fprintf(stdout,"+F3:%u:%u:%f:%f\n",
 | 
								fprintf(stdout,"+F3:%u:%u:%f:%f\n",
 | 
				
			||||||
				k,dsa_bits[k],dsa_results[k][0],dsa_results[k][1]);
 | 
									k,dsa_bits[k],dsa_results[k][0],dsa_results[k][1]);
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			fprintf(stdout,"dsa %4u bits %8.4fs %8.4fs %8.1f %8.1f\n",
 | 
								fprintf(stdout,"dsa %4u bits %8.6fs %8.6fs %8.1f %8.1f\n",
 | 
				
			||||||
				dsa_bits[k],dsa_results[k][0],dsa_results[k][1],
 | 
									dsa_bits[k],dsa_results[k][0],dsa_results[k][1],
 | 
				
			||||||
				1.0/dsa_results[k][0],1.0/dsa_results[k][1]);
 | 
									1.0/dsa_results[k][0],1.0/dsa_results[k][1]);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -354,6 +354,7 @@ static int MS_CALLBACK cb(int ok, X509_STORE_CTX *ctx)
 | 
				
			|||||||
		if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
							if (ctx->error == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
				
			||||||
		/* Continue after extension errors too */
 | 
							/* Continue after extension errors too */
 | 
				
			||||||
		if (ctx->error == X509_V_ERR_INVALID_CA) ok=1;
 | 
							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_PATH_LENGTH_EXCEEDED) ok=1;
 | 
				
			||||||
		if (ctx->error == X509_V_ERR_INVALID_PURPOSE) 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_DEPTH_ZERO_SELF_SIGNED_CERT) ok=1;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										20
									
								
								apps/x509.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								apps/x509.c
									
									
									
									
									
								
							@@ -179,7 +179,7 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	X509_REQ *rq=NULL;
 | 
						X509_REQ *rq=NULL;
 | 
				
			||||||
	int fingerprint=0;
 | 
						int fingerprint=0;
 | 
				
			||||||
	char buf[256];
 | 
						char buf[256];
 | 
				
			||||||
	const EVP_MD *md_alg,*digest=EVP_md5();
 | 
						const EVP_MD *md_alg,*digest;
 | 
				
			||||||
	CONF *extconf = NULL;
 | 
						CONF *extconf = NULL;
 | 
				
			||||||
	char *extsect = NULL, *extfile = NULL, *passin = NULL, *passargin = NULL;
 | 
						char *extsect = NULL, *extfile = NULL, *passin = NULL, *passargin = NULL;
 | 
				
			||||||
	int need_rand = 0;
 | 
						int need_rand = 0;
 | 
				
			||||||
@@ -216,6 +216,13 @@ int MAIN(int argc, char **argv)
 | 
				
			|||||||
	if (ctx == NULL) goto end;
 | 
						if (ctx == NULL) goto end;
 | 
				
			||||||
	X509_STORE_set_verify_cb_func(ctx,callb);
 | 
						X509_STORE_set_verify_cb_func(ctx,callb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef  OPENSSL_FIPS
 | 
				
			||||||
 | 
						if (FIPS_mode())
 | 
				
			||||||
 | 
							digest = EVP_sha1();
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
							digest = EVP_md5();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	argc--;
 | 
						argc--;
 | 
				
			||||||
	argv++;
 | 
						argv++;
 | 
				
			||||||
	num=0;
 | 
						num=0;
 | 
				
			||||||
@@ -598,9 +605,12 @@ bad:
 | 
				
			|||||||
			sno = ASN1_INTEGER_new();
 | 
								sno = ASN1_INTEGER_new();
 | 
				
			||||||
			if (!sno || !rand_serial(NULL, sno))
 | 
								if (!sno || !rand_serial(NULL, sno))
 | 
				
			||||||
				goto end;
 | 
									goto end;
 | 
				
			||||||
 | 
								if (!X509_set_serialNumber(x, sno)) 
 | 
				
			||||||
 | 
									goto end;
 | 
				
			||||||
 | 
								ASN1_INTEGER_free(sno);
 | 
				
			||||||
 | 
								sno = NULL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							else if (!X509_set_serialNumber(x, sno)) 
 | 
				
			||||||
		if (!X509_set_serialNumber(x, sno)) 
 | 
					 | 
				
			||||||
			goto end;
 | 
								goto end;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!X509_set_issuer_name(x,req->req_info->subject)) goto end;
 | 
							if (!X509_set_issuer_name(x,req->req_info->subject)) goto end;
 | 
				
			||||||
@@ -971,9 +981,9 @@ bad:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if (checkend)
 | 
						if (checkend)
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		time_t tnow=time(NULL);
 | 
							time_t tcheck=time(NULL) + checkoffset;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (ASN1_UTCTIME_cmp_time_t(X509_get_notAfter(x), tnow+checkoffset) == -1)
 | 
							if (X509_cmp_time(X509_get_notAfter(x), &tcheck) < 0)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			BIO_printf(out,"Certificate will expire\n");
 | 
								BIO_printf(out,"Certificate will expire\n");
 | 
				
			||||||
			ret=1;
 | 
								ret=1;
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										39
									
								
								argena.pem
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								argena.pem
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					-----BEGIN CERTIFICATE-----
 | 
				
			||||||
 | 
					MIIG0zCCBbugAwIBAgIBADANBgkqhkiG9w0BAQUFADCBzDELMAkGA1UEBhMCQVQx
 | 
				
			||||||
 | 
					EDAOBgNVBAgTB0F1c3RyaWExDzANBgNVBAcTBlZpZW5uYTE6MDgGA1UEChMxQVJH
 | 
				
			||||||
 | 
					RSBEQVRFTiAtIEF1c3RyaWFuIFNvY2lldHkgZm9yIERhdGEgUHJvdGVjdGlvbjEl
 | 
				
			||||||
 | 
					MCMGA1UECxMcQS1DRVJUIENlcnRpZmljYXRpb24gU2VydmljZTEYMBYGA1UEAxMP
 | 
				
			||||||
 | 
					QS1DRVJUIEFEVkFOQ0VEMR0wGwYJKoZIhvcNAQkBFg5pbmZvQGEtY2VydC5hdDAe
 | 
				
			||||||
 | 
					Fw0wNDEwMjMxNDE0MTRaFw0xMTEwMjMxNDE0MTRaMIHMMQswCQYDVQQGEwJBVDEQ
 | 
				
			||||||
 | 
					MA4GA1UECBMHQXVzdHJpYTEPMA0GA1UEBxMGVmllbm5hMTowOAYDVQQKEzFBUkdF
 | 
				
			||||||
 | 
					IERBVEVOIC0gQXVzdHJpYW4gU29jaWV0eSBmb3IgRGF0YSBQcm90ZWN0aW9uMSUw
 | 
				
			||||||
 | 
					IwYDVQQLExxBLUNFUlQgQ2VydGlmaWNhdGlvbiBTZXJ2aWNlMRgwFgYDVQQDEw9B
 | 
				
			||||||
 | 
					LUNFUlQgQURWQU5DRUQxHTAbBgkqhkiG9w0BCQEWDmluZm9AYS1jZXJ0LmF0MIIB
 | 
				
			||||||
 | 
					IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA3euXIy+mnf6BYKbK+QH5k679
 | 
				
			||||||
 | 
					tUFqeT8jlZxMew8eNiHuw9KoxWBzL6KksK+5uK7Gatw+sbAYntEGE80P+Jg1hADM
 | 
				
			||||||
 | 
					e+Fr5V0bc6QS3gkVtfUCW/RIvfMM39oxvmqJmOgPnJU7H6+nmLtsq61tv9kVJi/2
 | 
				
			||||||
 | 
					4Y5wXW3odet72sF57EoG6s78w0BUVLNcMngS9bZZzmdG3/d6JbkGgoNF/8DcgCBJ
 | 
				
			||||||
 | 
					W/t0JrcIzyppXIOVtUzzOrrU86zuUgT3Rtkl5kjG7DEHpFb9H0fTOY1v8+gRoaO6
 | 
				
			||||||
 | 
					2gA0PCiysgVZjwgVeYe3KAg11nznyleDv198uK3Dc1oXIGYjJx2FpKWUvAuAEwID
 | 
				
			||||||
 | 
					AQABo4ICvDCCArgwHQYDVR0OBBYEFDd/Pj6ZcWDKJNSRE3nQdCm0qCTYMIH5BgNV
 | 
				
			||||||
 | 
					HSMEgfEwge6AFDd/Pj6ZcWDKJNSRE3nQdCm0qCTYoYHSpIHPMIHMMQswCQYDVQQG
 | 
				
			||||||
 | 
					EwJBVDEQMA4GA1UECBMHQXVzdHJpYTEPMA0GA1UEBxMGVmllbm5hMTowOAYDVQQK
 | 
				
			||||||
 | 
					EzFBUkdFIERBVEVOIC0gQXVzdHJpYW4gU29jaWV0eSBmb3IgRGF0YSBQcm90ZWN0
 | 
				
			||||||
 | 
					aW9uMSUwIwYDVQQLExxBLUNFUlQgQ2VydGlmaWNhdGlvbiBTZXJ2aWNlMRgwFgYD
 | 
				
			||||||
 | 
					VQQDEw9BLUNFUlQgQURWQU5DRUQxHTAbBgkqhkiG9w0BCQEWDmluZm9AYS1jZXJ0
 | 
				
			||||||
 | 
					LmF0ggEAMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgHmMEcGA1UdJQRAMD4G
 | 
				
			||||||
 | 
					CCsGAQUFBwMBBggrBgEFBQcDAgYIKwYBBQUHAwMGCCsGAQUFBwMEBggrBgEFBQcD
 | 
				
			||||||
 | 
					CAYKKwYBBAGCNwoDBDARBglghkgBhvhCAQEEBAMCAP8wUQYDVR0gBEowSDBGBggq
 | 
				
			||||||
 | 
					KAAYAQEBAzA6MDgGCCsGAQUFBwIBFixodHRwOi8vd3d3LmEtY2VydC5hdC9jZXJ0
 | 
				
			||||||
 | 
					aWZpY2F0ZS1wb2xpY3kuaHRtbDA7BglghkgBhvhCAQgELhYsaHR0cDovL3d3dy5h
 | 
				
			||||||
 | 
					LWNlcnQuYXQvY2VydGlmaWNhdGUtcG9saWN5Lmh0bWwwGQYDVR0RBBIwEIEOaW5m
 | 
				
			||||||
 | 
					b0BhLWNlcnQuYXQwLwYDVR0SBCgwJoEOaW5mb0BhLWNlcnQuYXSGFGh0dHA6Ly93
 | 
				
			||||||
 | 
					d3cuYS1jZXJ0LmF0MEUGA1UdHwQ+MDwwOqA4oDaGNGh0dHBzOi8vc2VjdXJlLmEt
 | 
				
			||||||
 | 
					Y2VydC5hdC9jZ2ktYmluL2EtY2VydC1hZHZhbmNlZC5jZ2kwDQYJKoZIhvcNAQEF
 | 
				
			||||||
 | 
					BQADggEBACX1IvgfdG2rvfv35O48vSEvcVaEdlN8USFBHWz3JRAozgzvaBtwHkjK
 | 
				
			||||||
 | 
					Zwt5l/BWOtjbvHfRjDt7ijlBEcxOOrNC1ffyMHwHrXpvff6YpQ5wnxmIYEQcURiG
 | 
				
			||||||
 | 
					HMqruEX0WkuDNgSKwefsgXs27eeBauHgNGVcTYH1rmHu/ZyLpLxOyJQ2PCzA1DzW
 | 
				
			||||||
 | 
					3rWkIX92ogJ7lTRdWrbxwUL1XGinxnnaQ74+/y0pI9JNEv7ic2tpkweRMpkedaLW
 | 
				
			||||||
 | 
					msC1+orfKTebsg69aMaCx7o6jNONRmR/7TVaPf8/k6g52cHZ9YWjQvup22b5rWxG
 | 
				
			||||||
 | 
					J5r5LZ4vCPmF4+T4lutjUYAa/lGuQTg=
 | 
				
			||||||
 | 
					-----END CERTIFICATE-----
 | 
				
			||||||
							
								
								
									
										23
									
								
								argeng.pem
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								argeng.pem
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,23 @@
 | 
				
			|||||||
 | 
					-----BEGIN CERTIFICATE-----
 | 
				
			||||||
 | 
					MIIDwzCCAyygAwIBAgIBADANBgkqhkiG9w0BAQQFADCBmDELMAkGA1UEBhMCQVQx
 | 
				
			||||||
 | 
					EDAOBgNVBAgTB0F1c3RyaWExDzANBgNVBAcTBlZpZW5uYTFCMEAGA1UEChM5QXJn
 | 
				
			||||||
 | 
					ZSBEYXRlbiBPZXN0ZXJyZWljaGlzY2hlIEdlc2VsbHNjaGFmdCBmdWVyIERhdGVu
 | 
				
			||||||
 | 
					c2NodXR6MSIwIAYJKoZIhvcNAQkBFhNhLWNlcnRAYXJnZWRhdGVuLmF0MB4XDTAx
 | 
				
			||||||
 | 
					MDIxMjExMzAzMFoXDTA5MDIxMjExMzAzMFowgZgxCzAJBgNVBAYTAkFUMRAwDgYD
 | 
				
			||||||
 | 
					VQQIEwdBdXN0cmlhMQ8wDQYDVQQHEwZWaWVubmExQjBABgNVBAoTOUFyZ2UgRGF0
 | 
				
			||||||
 | 
					ZW4gT2VzdGVycmVpY2hpc2NoZSBHZXNlbGxzY2hhZnQgZnVlciBEYXRlbnNjaHV0
 | 
				
			||||||
 | 
					ejEiMCAGCSqGSIb3DQEJARYTYS1jZXJ0QGFyZ2VkYXRlbi5hdDCBnzANBgkqhkiG
 | 
				
			||||||
 | 
					9w0BAQEFAAOBjQAwgYkCgYEAwgsHqoNtmmrJ86+e1I4hOVBaL4kokqKN2IPOIL+1
 | 
				
			||||||
 | 
					XwY8vfOOUfPEdhWpaC0ldt7VYrksgDiUccgH0FROANWK2GkfKMDzjjXHysR04uEb
 | 
				
			||||||
 | 
					Om7Kqjqn0nproOGkFG+QvBZgs+Ws+HXNFJA6V76fU4+JXq4452LSK4Lr5YcBquu3
 | 
				
			||||||
 | 
					NJECAwEAAaOCARkwggEVMB0GA1UdDgQWBBQ0j59zH/G31zRjgK1y2P//tSAWZjCB
 | 
				
			||||||
 | 
					xQYDVR0jBIG9MIG6gBQ0j59zH/G31zRjgK1y2P//tSAWZqGBnqSBmzCBmDELMAkG
 | 
				
			||||||
 | 
					A1UEBhMCQVQxEDAOBgNVBAgTB0F1c3RyaWExDzANBgNVBAcTBlZpZW5uYTFCMEAG
 | 
				
			||||||
 | 
					A1UEChM5QXJnZSBEYXRlbiBPZXN0ZXJyZWljaGlzY2hlIEdlc2VsbHNjaGFmdCBm
 | 
				
			||||||
 | 
					dWVyIERhdGVuc2NodXR6MSIwIAYJKoZIhvcNAQkBFhNhLWNlcnRAYXJnZWRhdGVu
 | 
				
			||||||
 | 
					LmF0ggEAMAwGA1UdEwQFMAMBAf8wCwYDVR0PBAQDAgEGMBEGCWCGSAGG+EIBAQQE
 | 
				
			||||||
 | 
					AwICBDANBgkqhkiG9w0BAQQFAAOBgQBFuJYncqMYB6gXQS3eDOI90BEHfFTKy/dV
 | 
				
			||||||
 | 
					AV+K7QdAYikWmqgBheRdPKddJdccPy/Zl/p3ZT7GhDyC5f3wZjcuu8AJ27BNwbCA
 | 
				
			||||||
 | 
					x54dgxgCNcyPm79nY8MRtEdEpoRGdSsFKJemz6hpXM++MWFciyrRWIIA44XB0Gv3
 | 
				
			||||||
 | 
					US0spjsDPQ==
 | 
				
			||||||
 | 
					-----END CERTIFICATE-----
 | 
				
			||||||
@@ -1,59 +0,0 @@
 | 
				
			|||||||
Certificate:
 | 
					 | 
				
			||||||
    Data:
 | 
					 | 
				
			||||||
        Version: 3 (0x2)
 | 
					 | 
				
			||||||
        Serial Number: 1 (0x1)
 | 
					 | 
				
			||||||
        Signature Algorithm: md5WithRSAEncryption
 | 
					 | 
				
			||||||
        Issuer: O=European ICE-TEL project, OU=V3-Certification Authority
 | 
					 | 
				
			||||||
        Validity
 | 
					 | 
				
			||||||
            Not Before: Apr  2 17:35:53 1997 GMT
 | 
					 | 
				
			||||||
            Not After : Apr  2 17:35:53 1998 GMT
 | 
					 | 
				
			||||||
        Subject: O=European ICE-TEL project, OU=V3-Certification Authority, L=Darmstadt
 | 
					 | 
				
			||||||
        Subject Public Key Info:
 | 
					 | 
				
			||||||
            Public Key Algorithm: rsa
 | 
					 | 
				
			||||||
            RSA Public Key: (512 bit)
 | 
					 | 
				
			||||||
                Modulus (512 bit):
 | 
					 | 
				
			||||||
                    00:82:75:ba:f6:d1:60:b5:f9:15:b3:6a:dd:29:8f:
 | 
					 | 
				
			||||||
                    8b:a4:6f:1a:88:e0:50:43:40:0b:79:41:d5:d3:16:
 | 
					 | 
				
			||||||
                    44:7d:74:65:17:42:06:52:0b:e9:50:c8:10:cd:24:
 | 
					 | 
				
			||||||
                    e2:ae:8d:22:30:73:e6:b4:b7:93:1f:e5:6e:a2:ae:
 | 
					 | 
				
			||||||
                    49:11:a5:c9:45
 | 
					 | 
				
			||||||
                Exponent: 65537 (0x10001)
 | 
					 | 
				
			||||||
        X509v3 extensions:
 | 
					 | 
				
			||||||
            X509v3 Authority Key Identifier: 
 | 
					 | 
				
			||||||
                0.........z.."p......e..
 | 
					 | 
				
			||||||
            X509v3 Subject Key Identifier: 
 | 
					 | 
				
			||||||
                ..~r..:..B.44fu......3
 | 
					 | 
				
			||||||
            X509v3 Key Usage: critical
 | 
					 | 
				
			||||||
                ....
 | 
					 | 
				
			||||||
            X509v3 Certificate Policies: critical
 | 
					 | 
				
			||||||
                0.0...*...
 | 
					 | 
				
			||||||
            X509v3 Subject Alternative Name: 
 | 
					 | 
				
			||||||
                0!..secude-support@darmstadt.gmd.de
 | 
					 | 
				
			||||||
            X509v3 Issuer Alternative Name: 
 | 
					 | 
				
			||||||
                0I..ice-tel-ca@darmstadt.gmd.de.*http://www.darmstadt.gmd.de/ice-tel/euroca
 | 
					 | 
				
			||||||
            X509v3 Basic Constraints: critical
 | 
					 | 
				
			||||||
                0....
 | 
					 | 
				
			||||||
            X509v3 CRL Distribution Points: 
 | 
					 | 
				
			||||||
                0200...,.*http://www.darmstadt.gmd.de/ice-tel/euroca
 | 
					 | 
				
			||||||
    Signature Algorithm: md5WithRSAEncryption
 | 
					 | 
				
			||||||
        17:a2:88:b7:99:5a:05:41:e4:13:34:67:e6:1f:3e:26:ec:4b:
 | 
					 | 
				
			||||||
        69:f9:3e:28:22:be:9d:1c:ab:41:6f:0c:00:85:fe:45:74:f6:
 | 
					 | 
				
			||||||
        98:f0:ce:9b:65:53:4a:50:42:c7:d4:92:bd:d7:a2:a8:3d:98:
 | 
					 | 
				
			||||||
        88:73:cd:60:28:79:a3:fc:48:7a
 | 
					 | 
				
			||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIICzDCCAnagAwIBAgIBATANBgkqhkiG9w0BAQQFADBIMSEwHwYDVQQKExhFdXJv
 | 
					 | 
				
			||||||
cGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24g
 | 
					 | 
				
			||||||
QXV0aG9yaXR5MB4XDTk3MDQwMjE3MzU1M1oXDTk4MDQwMjE3MzU1M1owXDEhMB8G
 | 
					 | 
				
			||||||
A1UEChMYRXVyb3BlYW4gSUNFLVRFTCBwcm9qZWN0MSMwIQYDVQQLExpWMy1DZXJ0
 | 
					 | 
				
			||||||
aWZpY2F0aW9uIEF1dGhvcml0eTESMBAGA1UEBxMJRGFybXN0YWR0MFkwCgYEVQgB
 | 
					 | 
				
			||||||
AQICAgADSwAwSAJBAIJ1uvbRYLX5FbNq3SmPi6RvGojgUENAC3lB1dMWRH10ZRdC
 | 
					 | 
				
			||||||
BlIL6VDIEM0k4q6NIjBz5rS3kx/lbqKuSRGlyUUCAwEAAaOCATgwggE0MB8GA1Ud
 | 
					 | 
				
			||||||
IwQYMBaAFIr3yNUOx3ro1yJw4AuJ1bbsZbzPMB0GA1UdDgQWBBR+cvL4OoacQog0
 | 
					 | 
				
			||||||
NGZ1w9T80aIRMzAOBgNVHQ8BAf8EBAMCAfYwFAYDVR0gAQH/BAowCDAGBgQqAwQF
 | 
					 | 
				
			||||||
MCoGA1UdEQQjMCGBH3NlY3VkZS1zdXBwb3J0QGRhcm1zdGFkdC5nbWQuZGUwUgYD
 | 
					 | 
				
			||||||
VR0SBEswSYEbaWNlLXRlbC1jYUBkYXJtc3RhZHQuZ21kLmRlhipodHRwOi8vd3d3
 | 
					 | 
				
			||||||
LmRhcm1zdGFkdC5nbWQuZGUvaWNlLXRlbC9ldXJvY2EwDwYDVR0TAQH/BAUwAwEB
 | 
					 | 
				
			||||||
/zA7BgNVHR8ENDAyMDCgLqAshipodHRwOi8vd3d3LmRhcm1zdGFkdC5nbWQuZGUv
 | 
					 | 
				
			||||||
aWNlLXRlbC9ldXJvY2EwDQYJKoZIhvcNAQEEBQADQQAXooi3mVoFQeQTNGfmHz4m
 | 
					 | 
				
			||||||
7Etp+T4oIr6dHKtBbwwAhf5FdPaY8M6bZVNKUELH1JK916KoPZiIc81gKHmj/Eh6
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,48 +0,0 @@
 | 
				
			|||||||
Certificate:
 | 
					 | 
				
			||||||
    Data:
 | 
					 | 
				
			||||||
        Version: 3 (0x2)
 | 
					 | 
				
			||||||
        Serial Number: 0 (0x0)
 | 
					 | 
				
			||||||
        Signature Algorithm: md5WithRSAEncryption
 | 
					 | 
				
			||||||
        Issuer: O=European ICE-TEL project, OU=V3-Certification Authority
 | 
					 | 
				
			||||||
        Validity
 | 
					 | 
				
			||||||
            Not Before: Apr  2 17:33:36 1997 GMT
 | 
					 | 
				
			||||||
            Not After : Apr  2 17:33:36 1998 GMT
 | 
					 | 
				
			||||||
        Subject: O=European ICE-TEL project, OU=V3-Certification Authority
 | 
					 | 
				
			||||||
        Subject Public Key Info:
 | 
					 | 
				
			||||||
            Public Key Algorithm: rsa
 | 
					 | 
				
			||||||
            RSA Public Key: (512 bit)
 | 
					 | 
				
			||||||
                Modulus (512 bit):
 | 
					 | 
				
			||||||
                    00:80:3e:eb:ae:47:a9:fe:10:54:0b:81:8b:9c:2b:
 | 
					 | 
				
			||||||
                    82:ab:3a:61:36:65:8b:f3:73:9f:ac:ac:7a:15:a7:
 | 
					 | 
				
			||||||
                    13:8f:b4:c4:ba:a3:0f:bc:a5:58:8d:cc:b1:93:31:
 | 
					 | 
				
			||||||
                    9e:81:9e:8c:19:61:86:fa:52:73:54:d1:97:76:22:
 | 
					 | 
				
			||||||
                    e7:c7:9f:41:cd
 | 
					 | 
				
			||||||
                Exponent: 65537 (0x10001)
 | 
					 | 
				
			||||||
        X509v3 extensions:
 | 
					 | 
				
			||||||
            X509v3 Subject Key Identifier: 
 | 
					 | 
				
			||||||
                ........z.."p......e..
 | 
					 | 
				
			||||||
            X509v3 Key Usage: critical
 | 
					 | 
				
			||||||
                ....
 | 
					 | 
				
			||||||
            X509v3 Subject Alternative Name: 
 | 
					 | 
				
			||||||
                0I.*http://www.darmstadt.gmd.de/ice-tel/euroca..ice-tel-ca@darmstadt.gmd.de
 | 
					 | 
				
			||||||
            X509v3 Basic Constraints: critical
 | 
					 | 
				
			||||||
                0....
 | 
					 | 
				
			||||||
    Signature Algorithm: md5WithRSAEncryption
 | 
					 | 
				
			||||||
        76:69:61:db:b7:cf:8b:06:9e:d8:8c:96:53:d2:4d:a8:23:a6:
 | 
					 | 
				
			||||||
        03:44:e8:8f:24:a5:c0:84:a8:4b:77:d4:2d:2b:7d:37:91:67:
 | 
					 | 
				
			||||||
        f2:2c:ce:02:31:4c:6b:cc:ce:f2:68:a6:11:11:ab:7d:88:b8:
 | 
					 | 
				
			||||||
        7e:22:9f:25:06:60:bd:79:30:3d
 | 
					 | 
				
			||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIICFjCCAcCgAwIBAgIBADANBgkqhkiG9w0BAQQFADBIMSEwHwYDVQQKExhFdXJv
 | 
					 | 
				
			||||||
cGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24g
 | 
					 | 
				
			||||||
QXV0aG9yaXR5MB4XDTk3MDQwMjE3MzMzNloXDTk4MDQwMjE3MzMzNlowSDEhMB8G
 | 
					 | 
				
			||||||
A1UEChMYRXVyb3BlYW4gSUNFLVRFTCBwcm9qZWN0MSMwIQYDVQQLExpWMy1DZXJ0
 | 
					 | 
				
			||||||
aWZpY2F0aW9uIEF1dGhvcml0eTBZMAoGBFUIAQECAgIAA0sAMEgCQQCAPuuuR6n+
 | 
					 | 
				
			||||||
EFQLgYucK4KrOmE2ZYvzc5+srHoVpxOPtMS6ow+8pViNzLGTMZ6BnowZYYb6UnNU
 | 
					 | 
				
			||||||
0Zd2IufHn0HNAgMBAAGjgZcwgZQwHQYDVR0OBBYEFIr3yNUOx3ro1yJw4AuJ1bbs
 | 
					 | 
				
			||||||
ZbzPMA4GA1UdDwEB/wQEAwIB9jBSBgNVHREESzBJhipodHRwOi8vd3d3LmRhcm1z
 | 
					 | 
				
			||||||
dGFkdC5nbWQuZGUvaWNlLXRlbC9ldXJvY2GBG2ljZS10ZWwtY2FAZGFybXN0YWR0
 | 
					 | 
				
			||||||
LmdtZC5kZTAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBBAUAA0EAdmlh27fP
 | 
					 | 
				
			||||||
iwae2IyWU9JNqCOmA0TojySlwISoS3fULSt9N5Fn8izOAjFMa8zO8mimERGrfYi4
 | 
					 | 
				
			||||||
fiKfJQZgvXkwPQ==
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,63 +0,0 @@
 | 
				
			|||||||
Certificate:
 | 
					 | 
				
			||||||
    Data:
 | 
					 | 
				
			||||||
        Version: 3 (0x2)
 | 
					 | 
				
			||||||
        Serial Number: 1 (0x1)
 | 
					 | 
				
			||||||
        Signature Algorithm: md5WithRSAEncryption
 | 
					 | 
				
			||||||
        Issuer: O=European ICE-TEL project, OU=V3-Certification Authority, L=Darmstadt
 | 
					 | 
				
			||||||
        Validity
 | 
					 | 
				
			||||||
            Not Before: Apr  2 17:35:59 1997 GMT
 | 
					 | 
				
			||||||
            Not After : Apr  2 17:35:59 1998 GMT
 | 
					 | 
				
			||||||
        Subject: O=European ICE-TEL project, OU=V3-Certification Authority, L=Darmstadt, CN=USER
 | 
					 | 
				
			||||||
        Subject Public Key Info:
 | 
					 | 
				
			||||||
            Public Key Algorithm: rsa
 | 
					 | 
				
			||||||
            RSA Public Key: (512 bit)
 | 
					 | 
				
			||||||
                Modulus (512 bit):
 | 
					 | 
				
			||||||
                    00:a8:a8:53:63:49:1b:93:c3:c3:0b:6c:88:11:55:
 | 
					 | 
				
			||||||
                    de:7e:6a:e2:f9:52:a0:dc:69:25:c4:c8:bf:55:e1:
 | 
					 | 
				
			||||||
                    31:a8:ce:e4:a9:29:85:99:8a:15:9a:de:f6:2f:e1:
 | 
					 | 
				
			||||||
                    b4:50:5f:5e:04:75:a6:f4:76:dc:3c:0e:39:dc:3a:
 | 
					 | 
				
			||||||
                    be:3e:a4:61:8b
 | 
					 | 
				
			||||||
                Exponent: 65537 (0x10001)
 | 
					 | 
				
			||||||
        X509v3 extensions:
 | 
					 | 
				
			||||||
            X509v3 Authority Key Identifier: 
 | 
					 | 
				
			||||||
                0...~r..:..B.44fu......3
 | 
					 | 
				
			||||||
            X509v3 Subject Key Identifier: 
 | 
					 | 
				
			||||||
                ...... .*...1.*.......
 | 
					 | 
				
			||||||
            X509v3 Key Usage: critical
 | 
					 | 
				
			||||||
                ....
 | 
					 | 
				
			||||||
            X509v3 Certificate Policies: critical
 | 
					 | 
				
			||||||
                0.0...*...0.......
 | 
					 | 
				
			||||||
            X509v3 Subject Alternative Name: 
 | 
					 | 
				
			||||||
                0:..user@darmstadt.gmd.de.!http://www.darmstadt.gmd.de/~user
 | 
					 | 
				
			||||||
            X509v3 Issuer Alternative Name: 
 | 
					 | 
				
			||||||
                0....gmdca@gmd.de..http://www.gmd.de..saturn.darmstadt.gmd.de.\1!0...U.
 | 
					 | 
				
			||||||
..European ICE-TEL project1#0!..U....V3-Certification Authority1.0...U....Darmstadt..141.12.62.26
 | 
					 | 
				
			||||||
            X509v3 Basic Constraints: critical
 | 
					 | 
				
			||||||
                0.
 | 
					 | 
				
			||||||
            X509v3 CRL Distribution Points: 
 | 
					 | 
				
			||||||
                0.0.......gmdca@gmd.de
 | 
					 | 
				
			||||||
    Signature Algorithm: md5WithRSAEncryption
 | 
					 | 
				
			||||||
        69:0c:e1:b7:a7:f2:d8:fb:e8:69:c0:13:cd:37:ad:21:06:22:
 | 
					 | 
				
			||||||
        4d:e8:c6:db:f1:04:0b:b7:e0:b3:d6:0c:81:03:ce:c3:6a:3e:
 | 
					 | 
				
			||||||
        c7:e7:24:24:a4:92:64:c2:83:83:06:42:53:0e:6f:09:1e:84:
 | 
					 | 
				
			||||||
        9a:f7:6f:63:9b:94:99:83:d6:a4
 | 
					 | 
				
			||||||
-----BEGIN CERTIFICATE-----
 | 
					 | 
				
			||||||
MIIDTzCCAvmgAwIBAgIBATANBgkqhkiG9w0BAQQFADBcMSEwHwYDVQQKExhFdXJv
 | 
					 | 
				
			||||||
cGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24g
 | 
					 | 
				
			||||||
QXV0aG9yaXR5MRIwEAYDVQQHEwlEYXJtc3RhZHQwHhcNOTcwNDAyMTczNTU5WhcN
 | 
					 | 
				
			||||||
OTgwNDAyMTczNTU5WjBrMSEwHwYDVQQKExhFdXJvcGVhbiBJQ0UtVEVMIHByb2pl
 | 
					 | 
				
			||||||
Y3QxIzAhBgNVBAsTGlYzLUNlcnRpZmljYXRpb24gQXV0aG9yaXR5MRIwEAYDVQQH
 | 
					 | 
				
			||||||
EwlEYXJtc3RhZHQxDTALBgNVBAMTBFVTRVIwWTAKBgRVCAEBAgICAANLADBIAkEA
 | 
					 | 
				
			||||||
qKhTY0kbk8PDC2yIEVXefmri+VKg3GklxMi/VeExqM7kqSmFmYoVmt72L+G0UF9e
 | 
					 | 
				
			||||||
BHWm9HbcPA453Dq+PqRhiwIDAQABo4IBmDCCAZQwHwYDVR0jBBgwFoAUfnLy+DqG
 | 
					 | 
				
			||||||
nEKINDRmdcPU/NGiETMwHQYDVR0OBBYEFJfc4B8gjSoRmLUx4Sq/ucIYiMrPMA4G
 | 
					 | 
				
			||||||
A1UdDwEB/wQEAwIB8DAcBgNVHSABAf8EEjAQMAYGBCoDBAUwBgYECQgHBjBDBgNV
 | 
					 | 
				
			||||||
HREEPDA6gRV1c2VyQGRhcm1zdGFkdC5nbWQuZGWGIWh0dHA6Ly93d3cuZGFybXN0
 | 
					 | 
				
			||||||
YWR0LmdtZC5kZS9+dXNlcjCBsQYDVR0SBIGpMIGmgQxnbWRjYUBnbWQuZGWGEWh0
 | 
					 | 
				
			||||||
dHA6Ly93d3cuZ21kLmRlghdzYXR1cm4uZGFybXN0YWR0LmdtZC5kZaRcMSEwHwYD
 | 
					 | 
				
			||||||
VQQKExhFdXJvcGVhbiBJQ0UtVEVMIHByb2plY3QxIzAhBgNVBAsTGlYzLUNlcnRp
 | 
					 | 
				
			||||||
ZmljYXRpb24gQXV0aG9yaXR5MRIwEAYDVQQHEwlEYXJtc3RhZHSHDDE0MS4xMi42
 | 
					 | 
				
			||||||
Mi4yNjAMBgNVHRMBAf8EAjAAMB0GA1UdHwQWMBQwEqAQoA6BDGdtZGNhQGdtZC5k
 | 
					 | 
				
			||||||
ZTANBgkqhkiG9w0BAQQFAANBAGkM4ben8tj76GnAE803rSEGIk3oxtvxBAu34LPW
 | 
					 | 
				
			||||||
DIEDzsNqPsfnJCSkkmTCg4MGQlMObwkehJr3b2OblJmD1qQ=
 | 
					 | 
				
			||||||
-----END CERTIFICATE-----
 | 
					 | 
				
			||||||
@@ -1,9 +0,0 @@
 | 
				
			|||||||
-----BEGIN X509 CRL-----
 | 
					 | 
				
			||||||
MIIBNDCBnjANBgkqhkiG9w0BAQIFADBFMSEwHwYDVQQKExhFdXJvcGVhbiBJQ0Ut
 | 
					 | 
				
			||||||
VEVMIFByb2plY3QxIDAeBgNVBAsTF0NlcnRpZmljYXRpb24gQXV0aG9yaXR5Fw05
 | 
					 | 
				
			||||||
NzA2MDkxNDQyNDNaFw05NzA3MDkxNDQyNDNaMCgwEgIBChcNOTcwMzAzMTQ0MjU0
 | 
					 | 
				
			||||||
WjASAgEJFw05NjEwMDIxMjI5MjdaMA0GCSqGSIb3DQEBAgUAA4GBAH4vgWo2Tej/
 | 
					 | 
				
			||||||
i7kbiw4Imd30If91iosjClNpBFwvwUDBclPEeMuYimHbLOk4H8Nofc0fw11+U/IO
 | 
					 | 
				
			||||||
KSNouUDcqG7B64oY7c4SXKn+i1MWOb5OJiWeodX3TehHjBlyWzoNMWCnYA8XqFP1
 | 
					 | 
				
			||||||
mOKp8Jla1BibEZf14+/HqCi2hnZUiEXh
 | 
					 | 
				
			||||||
-----END X509 CRL-----
 | 
					 | 
				
			||||||
							
								
								
									
										23
									
								
								certs/wellsfgo.pem
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								certs/wellsfgo.pem
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,23 @@
 | 
				
			|||||||
 | 
					-----BEGIN CERTIFICATE-----
 | 
				
			||||||
 | 
					MIID5TCCAs2gAwIBAgIEOeSXnjANBgkqhkiG9w0BAQUFADCBgjELMAkGA1UEBhMC
 | 
				
			||||||
 | 
					VVMxFDASBgNVBAoTC1dlbGxzIEZhcmdvMSwwKgYDVQQLEyNXZWxscyBGYXJnbyBD
 | 
				
			||||||
 | 
					ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEvMC0GA1UEAxMmV2VsbHMgRmFyZ28gUm9v
 | 
				
			||||||
 | 
					dCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcNMDAxMDExMTY0MTI4WhcNMjEwMTE0
 | 
				
			||||||
 | 
					MTY0MTI4WjCBgjELMAkGA1UEBhMCVVMxFDASBgNVBAoTC1dlbGxzIEZhcmdvMSww
 | 
				
			||||||
 | 
					KgYDVQQLEyNXZWxscyBGYXJnbyBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEvMC0G
 | 
				
			||||||
 | 
					A1UEAxMmV2VsbHMgRmFyZ28gUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEi
 | 
				
			||||||
 | 
					MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDVqDM7Jvk0/82bfuUER84A4n13
 | 
				
			||||||
 | 
					5zHCLielTWi5MbqNQ1mXx3Oqfz1cQJ4F5aHiidlMuD+b+Qy0yGIZLEWukR5zcUHE
 | 
				
			||||||
 | 
					SxP9cMIlrCL1dQu3U+SlK93OvRw6esP3E48mVJwWa2uv+9iWsWCaSOAlIiR5NM4O
 | 
				
			||||||
 | 
					JgALTqv9i86C1y8IcGjBqAr5dE8Hq6T54oN+J3N0Prj5OEL8pahbSCOz6+MlsoCu
 | 
				
			||||||
 | 
					ltQKnMJ4msZoGK43YjdeUXWoWGPAUe5AeH6orxqg4bB4nVCMe+ez/I4jsNtlAHCE
 | 
				
			||||||
 | 
					AQgAFG5Uhpq6zPk3EPbg3oQtnaSFN9OH4xXQwReQfhkhahKpdv0SAulPIV4XAgMB
 | 
				
			||||||
 | 
					AAGjYTBfMA8GA1UdEwEB/wQFMAMBAf8wTAYDVR0gBEUwQzBBBgtghkgBhvt7hwcB
 | 
				
			||||||
 | 
					CzAyMDAGCCsGAQUFBwIBFiRodHRwOi8vd3d3LndlbGxzZmFyZ28uY29tL2NlcnRw
 | 
				
			||||||
 | 
					b2xpY3kwDQYJKoZIhvcNAQEFBQADggEBANIn3ZwKdyu7IvICtUpKkfnRLb7kuxpo
 | 
				
			||||||
 | 
					7w6kAOnu5+/u9vnldKTC2FJYxHT7zmu1Oyl5GFrvm+0fazbuSCUlFLZWohDo7qd/
 | 
				
			||||||
 | 
					0D+j0MNdJu4HzMPBJCGHHt8qElNvQRbn7a6U+oxy+hNH8Dx+rn0ROhPs7fpvcmR7
 | 
				
			||||||
 | 
					nX1/Jv16+yWt6j4pf0zjAFcysLPp7VMX2YuyFA4w6OXVE8Zkr8QA1dhYJPz1j+zx
 | 
				
			||||||
 | 
					x32l2w8n0cbyQIjmH/ZhqPRCyLk306m+LFZ4wnKbWV01QIroTmMatukgalHizqSQ
 | 
				
			||||||
 | 
					33ZwmVxwQ023tqcZZE6St8WRPH9IFmV7Fv3L/PvZ1dZPIWU7Sn9Ho/s=
 | 
				
			||||||
 | 
					-----END CERTIFICATE-----
 | 
				
			||||||
							
								
								
									
										117
									
								
								config
									
									
									
									
									
								
							
							
						
						
									
										117
									
								
								config
									
									
									
									
									
								
							@@ -111,16 +111,16 @@ case "${SYSTEM}:${RELEASE}:${VERSION}:${MACHINE}" in
 | 
				
			|||||||
	echo "m68k-apple-aux3"; exit 0
 | 
						echo "m68k-apple-aux3"; exit 0
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    AIX:[3456789]:4:*)
 | 
					    AIX:[3-9]:4:*)
 | 
				
			||||||
	echo "${MACHINE}-ibm-aix43"; exit 0
 | 
						echo "${MACHINE}-ibm-aix"; exit 0
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    AIX:*:[56789]:*)
 | 
					    AIX:*:[5-9]:*)
 | 
				
			||||||
	echo "${MACHINE}-ibm-aix43"; exit 0
 | 
						echo "${MACHINE}-ibm-aix"; exit 0
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    AIX:*)
 | 
					    AIX:*)
 | 
				
			||||||
	echo "${MACHINE}-ibm-aix"; exit 0
 | 
						echo "${MACHINE}-ibm-aix3"; exit 0
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    dgux:*)
 | 
					    dgux:*)
 | 
				
			||||||
@@ -337,6 +337,9 @@ case "${SYSTEM}:${RELEASE}:${VERSION}:${MACHINE}" in
 | 
				
			|||||||
	echo "mips-sony-newsos4"; exit 0;
 | 
						echo "mips-sony-newsos4"; exit 0;
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    MINGW*)
 | 
				
			||||||
 | 
						echo "${MACHINE}-whatever-mingw"; echo 0;
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
    CYGWIN*)
 | 
					    CYGWIN*)
 | 
				
			||||||
	case "$RELEASE" in
 | 
						case "$RELEASE" in
 | 
				
			||||||
	    [bB]*|1.0|1.[12].*)
 | 
						    [bB]*|1.0|1.[12].*)
 | 
				
			||||||
@@ -442,7 +445,7 @@ if [ "$SYSTEM" = "SunOS" ]; then
 | 
				
			|||||||
  	egrep -e '^cc: .* C [0-9]\.[0-9]' | \
 | 
					  	egrep -e '^cc: .* C [0-9]\.[0-9]' | \
 | 
				
			||||||
	sed 's/.* C \([0-9]\)\.\([0-9]\).*/\1\2/'`
 | 
						sed 's/.* C \([0-9]\)\.\([0-9]\).*/\1\2/'`
 | 
				
			||||||
  CCVER=${CCVER:-0}
 | 
					  CCVER=${CCVER:-0}
 | 
				
			||||||
  if [ $CCVER -gt 40 ]; then
 | 
					  if [ $MACHINE != i86pc -a $CCVER -gt 40 ]; then
 | 
				
			||||||
    CC=cc	# overrides gcc!!!
 | 
					    CC=cc	# overrides gcc!!!
 | 
				
			||||||
    if [ $CCVER -eq 50 ]; then
 | 
					    if [ $CCVER -eq 50 ]; then
 | 
				
			||||||
      echo "WARNING! Detected WorkShop C 5.0. Do make sure you have"
 | 
					      echo "WARNING! Detected WorkShop C 5.0. Do make sure you have"
 | 
				
			||||||
@@ -491,29 +494,29 @@ case "$GUESSOS" in
 | 
				
			|||||||
	OUT="irix-$CC"
 | 
						OUT="irix-$CC"
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
  mips3-sgi-irix)
 | 
					  mips3-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}
 | 
				
			||||||
	if [ $CPU -ge 5000 ]; then
 | 
						#if [ $CPU -ge 5000 ]; then
 | 
				
			||||||
		options="$options -mips4"
 | 
						#	options="$options -mips4"
 | 
				
			||||||
	else
 | 
						#else
 | 
				
			||||||
		options="$options -mips3"
 | 
						#	options="$options -mips3"
 | 
				
			||||||
	fi
 | 
						#fi
 | 
				
			||||||
	OUT="irix-mips3-$CC"
 | 
						OUT="irix-mips3-$CC"
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
  mips4-sgi-irix64)
 | 
					  mips4-sgi-irix64)
 | 
				
			||||||
	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 irix64-mips4-$CC' *manually*."
 | 
						echo "         invoke './Configure irix64-mips4-$CC' *manually*."
 | 
				
			||||||
	if [ "$TEST" = "false" ]; then
 | 
						if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
	  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
						  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
	  (stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
						  (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
        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}
 | 
				
			||||||
        if [ $CPU -ge 5000 ]; then
 | 
					        #if [ $CPU -ge 5000 ]; then
 | 
				
			||||||
                options="$options -mips4"
 | 
					        #        options="$options -mips4"
 | 
				
			||||||
        else
 | 
					        #else
 | 
				
			||||||
                options="$options -mips3"
 | 
					        #        options="$options -mips3"
 | 
				
			||||||
        fi
 | 
					        #fi
 | 
				
			||||||
	OUT="irix-mips3-$CC"
 | 
						OUT="irix-mips3-$CC"
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
  alpha-*-linux2)
 | 
					  alpha-*-linux2)
 | 
				
			||||||
@@ -547,9 +550,14 @@ EOF
 | 
				
			|||||||
	rm dummy dummy.c
 | 
						rm dummy dummy.c
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
  ppc64-*-linux2)
 | 
					  ppc64-*-linux2)
 | 
				
			||||||
	#Use the standard target for PPC architecture until we create a
 | 
						echo "WARNING! If you wish to build 64-bit library, then you have to"
 | 
				
			||||||
	#special one for the 64bit architecture.
 | 
						echo "         invoke './Configure linux-ppc64' *manually*."
 | 
				
			||||||
	OUT="linux-ppc" ;;
 | 
						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
 | 
				
			||||||
 | 
						OUT="linux-ppc"
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
  ppc-*-linux2) OUT="linux-ppc" ;;
 | 
					  ppc-*-linux2) OUT="linux-ppc" ;;
 | 
				
			||||||
  m68k-*-linux*) OUT="linux-m68k" ;;
 | 
					  m68k-*-linux*) OUT="linux-m68k" ;;
 | 
				
			||||||
  ia64-*-linux?) OUT="linux-ia64" ;;
 | 
					  ia64-*-linux?) OUT="linux-ia64" ;;
 | 
				
			||||||
@@ -560,9 +568,9 @@ EOF
 | 
				
			|||||||
	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"
 | 
				
			||||||
	echo "         and wish to build 64-bit library, then you have to"
 | 
						echo "         and wish to build 64-bit library, then you have to"
 | 
				
			||||||
	echo "         invoke './Configure linux64-sparcv9' *manually*."
 | 
						echo "         invoke './Configure linux64-sparcv9' *manually*."
 | 
				
			||||||
	if [ "$TEST" = "false" ]; then
 | 
						if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
	  echo "          You have about 5 seconds to press Ctrl-C to abort."
 | 
						  echo "          You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
	  (stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
						  (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
	OUT="linux-sparcv9" ;;
 | 
						OUT="linux-sparcv9" ;;
 | 
				
			||||||
  sparc-*-linux2)
 | 
					  sparc-*-linux2)
 | 
				
			||||||
@@ -593,7 +601,9 @@ EOF
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	options="$options -mschedule=$CPUSCHEDULE -march=$CPUARCH"
 | 
						options="$options -mschedule=$CPUSCHEDULE -march=$CPUARCH"
 | 
				
			||||||
	OUT="linux-parisc" ;;
 | 
						OUT="linux-parisc" ;;
 | 
				
			||||||
  arm*-*-linux2) OUT="linux-elf-arm" ;;
 | 
					  arm*b-*-linux2) OUT="linux-elf-arm"; options="$options -DB_ENDIAN" ;;
 | 
				
			||||||
 | 
					  arm*l-*-linux2) OUT="linux-elf-arm"; options="$options -DL_ENDIAN" ;;
 | 
				
			||||||
 | 
					  arm*-*-linux2)  OUT="linux-elf-arm" ;;
 | 
				
			||||||
  s390-*-linux2) OUT="linux-s390" ;;
 | 
					  s390-*-linux2) OUT="linux-s390" ;;
 | 
				
			||||||
  s390x-*-linux?) OUT="linux-s390x" ;;
 | 
					  s390x-*-linux?) OUT="linux-s390x" ;;
 | 
				
			||||||
  x86_64-*-linux?) OUT="linux-x86_64" ;;
 | 
					  x86_64-*-linux?) OUT="linux-x86_64" ;;
 | 
				
			||||||
@@ -617,9 +627,9 @@ EOF
 | 
				
			|||||||
	    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*."
 | 
				
			||||||
		if [ "$TEST" = "false" ]; then
 | 
							if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
		  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
							  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
		  (stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
							  (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
		fi
 | 
							fi
 | 
				
			||||||
	    elif [ "$CC" = "gcc" -a "$GCC_ARCH" = "-m64" ]; then
 | 
						    elif [ "$CC" = "gcc" -a "$GCC_ARCH" = "-m64" ]; then
 | 
				
			||||||
		# $GCC_ARCH denotes default ABI chosen by compiler driver
 | 
							# $GCC_ARCH denotes default ABI chosen by compiler driver
 | 
				
			||||||
@@ -629,17 +639,17 @@ EOF
 | 
				
			|||||||
		OUT="solaris64-sparcv9-gcc"
 | 
							OUT="solaris64-sparcv9-gcc"
 | 
				
			||||||
		echo "WARNING! If you wish to build 32-bit library, then you have to"
 | 
							echo "WARNING! If you wish to build 32-bit library, then you have to"
 | 
				
			||||||
		echo "         invoke './Configure solaris-sparcv9-gcc' *manually*."
 | 
							echo "         invoke './Configure solaris-sparcv9-gcc' *manually*."
 | 
				
			||||||
		if [ "$TEST" = "false" ]; then
 | 
							if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
		  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
							  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
		  (stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
							  (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
		fi
 | 
							fi
 | 
				
			||||||
	    elif [ "$GCC_ARCH" = "-m32" ]; then
 | 
						    elif [ "$GCC_ARCH" = "-m32" ]; then
 | 
				
			||||||
		echo "NOTICE! If you *know* that your GNU C supports 64-bit/V9 ABI"
 | 
							echo "NOTICE! If you *know* that your GNU C supports 64-bit/V9 ABI"
 | 
				
			||||||
		echo "        and wish to build 64-bit library, then you have to"
 | 
							echo "        and wish to build 64-bit library, then you have to"
 | 
				
			||||||
		echo "        invoke './Configure solaris64-sparcv9-gcc' *manually*."
 | 
							echo "        invoke './Configure solaris64-sparcv9-gcc' *manually*."
 | 
				
			||||||
		if [ "$TEST" = "false" ]; then
 | 
							if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
		  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
							  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
		  (stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
							  (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
		fi
 | 
							fi
 | 
				
			||||||
	    fi
 | 
						    fi
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
@@ -647,7 +657,14 @@ EOF
 | 
				
			|||||||
  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) OUT="solaris-x86-$CC" ;;
 | 
					  *86*-*-solaris2)
 | 
				
			||||||
 | 
						ISA64=`(isalist) 2>/dev/null | grep amd64`
 | 
				
			||||||
 | 
						if [ "$ISA64" != "" ]; then
 | 
				
			||||||
 | 
						    OUT="solaris64-x86_64-$CC"
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						    OUT="solaris-x86-$CC"
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
  *-*-sunos4) OUT="sunos-$CC" ;;
 | 
					  *-*-sunos4) OUT="sunos-$CC" ;;
 | 
				
			||||||
  alpha*-*-freebsd*) OUT="FreeBSD-alpha" ;;
 | 
					  alpha*-*-freebsd*) OUT="FreeBSD-alpha" ;;
 | 
				
			||||||
  sparc64-*-freebsd*) OUT="FreeBSD-sparc64" ;;
 | 
					  sparc64-*-freebsd*) OUT="FreeBSD-sparc64" ;;
 | 
				
			||||||
@@ -715,9 +732,9 @@ EOF
 | 
				
			|||||||
	     echo "WARNING! 64-bit ABI is the default configured ABI on HP-UXi."
 | 
						     echo "WARNING! 64-bit ABI is the default configured ABI on HP-UXi."
 | 
				
			||||||
	     echo "         If you wish to build 32-bit library, the you have to"
 | 
						     echo "         If you wish to build 32-bit library, the you have to"
 | 
				
			||||||
	     echo "         invoke './Configure hpux-ia64-cc' *manually*."
 | 
						     echo "         invoke './Configure hpux-ia64-cc' *manually*."
 | 
				
			||||||
	     if [ "$TEST" = "false" ]; then
 | 
						     if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
		echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
							echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
		(stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
							(trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
	     fi
 | 
						     fi
 | 
				
			||||||
	     OUT="hpux64-ia64-cc"
 | 
						     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
 | 
				
			||||||
@@ -727,9 +744,9 @@ EOF
 | 
				
			|||||||
	     if [ $KERNEL_BITS -eq 64 -a "$CC" = "cc" ]; then
 | 
						     if [ $KERNEL_BITS -eq 64 -a "$CC" = "cc" ]; 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 hpux64-parisc2-cc' *manually*."
 | 
							echo "         invoke './Configure hpux64-parisc2-cc' *manually*."
 | 
				
			||||||
		if [ "$TEST" = "false" ]; then
 | 
							if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
		  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
							  echo "         You have about 5 seconds to press Ctrl-C to abort."
 | 
				
			||||||
		  (stty -icanon min 0 time 50; read waste) < /dev/tty
 | 
							  (trap "stty `stty -g`" 2 0; stty -icanon min 0 time 50; read waste) <&1
 | 
				
			||||||
		fi
 | 
							fi
 | 
				
			||||||
	     fi
 | 
						     fi
 | 
				
			||||||
	elif [ $CPU_VERSION -ge 528 ]; then	# PA-RISC 1.1+ CPU
 | 
						elif [ $CPU_VERSION -ge 528 ]; then	# PA-RISC 1.1+ CPU
 | 
				
			||||||
@@ -741,8 +758,28 @@ EOF
 | 
				
			|||||||
	fi
 | 
						fi
 | 
				
			||||||
	options="$options -D_REENTRANT" ;;
 | 
						options="$options -D_REENTRANT" ;;
 | 
				
			||||||
  *-hpux)	OUT="hpux-parisc-$CC" ;;
 | 
					  *-hpux)	OUT="hpux-parisc-$CC" ;;
 | 
				
			||||||
 | 
					  *-aix)
 | 
				
			||||||
 | 
						KERNEL_BITS=`(getconf KERNEL_BITMODE) 2>/dev/null`
 | 
				
			||||||
 | 
						KERNEL_BITS=${KERNEL_BITS:-32}
 | 
				
			||||||
 | 
						OBJECT_MODE=${OBJECT_MODE:-32}
 | 
				
			||||||
 | 
						if [ "$CC" = "gcc" ]; then
 | 
				
			||||||
 | 
						    OUT="aix-gcc"
 | 
				
			||||||
 | 
						elif [ $OBJECT_MODE -eq 64 ]; then
 | 
				
			||||||
 | 
						    echo 'Your $OBJECT_MODE was found to be set to 64' 
 | 
				
			||||||
 | 
						    OUT="aix64-cc"
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
 | 
						    OUT="aix-cc"
 | 
				
			||||||
 | 
						    if [ $KERNEL_BITS -eq 64 ]; then
 | 
				
			||||||
 | 
							echo "WARNING! If you wish to build 64-bit kit, then you have to"
 | 
				
			||||||
 | 
							echo "         invoke './Configure aix64-cc' *manually*."
 | 
				
			||||||
 | 
							if [ "$TEST" = "false" -a -t 1 ]; then
 | 
				
			||||||
 | 
							    echo "         You have ~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
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
  # these are all covered by the catchall below
 | 
					  # these are all covered by the catchall below
 | 
				
			||||||
  # *-aix) OUT="aix-$CC" ;;
 | 
					 | 
				
			||||||
  # *-dgux) OUT="dgux" ;;
 | 
					  # *-dgux) OUT="dgux" ;;
 | 
				
			||||||
  mips-sony-newsos4) OUT="newsos4-gcc" ;;
 | 
					  mips-sony-newsos4) OUT="newsos4-gcc" ;;
 | 
				
			||||||
  *-*-cygwin_pre1.3) OUT="Cygwin-pre1.3" ;;
 | 
					  *-*-cygwin_pre1.3) OUT="Cygwin-pre1.3" ;;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,3 +2,5 @@ lib
 | 
				
			|||||||
buildinf.h
 | 
					buildinf.h
 | 
				
			||||||
opensslconf.h
 | 
					opensslconf.h
 | 
				
			||||||
Makefile.save
 | 
					Makefile.save
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -94,7 +94,8 @@ lib:	$(LIBOBJ)
 | 
				
			|||||||
	@touch lib
 | 
						@touch lib
 | 
				
			||||||
 | 
					
 | 
				
			||||||
shared: buildinf.h lib subdirs
 | 
					shared: buildinf.h lib subdirs
 | 
				
			||||||
	if [ -n "$(SHARED_LIBS)" ]; then \
 | 
						@if [ -n "$(SHARED_LIBS)" ]; then \
 | 
				
			||||||
 | 
							egrep 'define OPENSSL_FIPS' $(TOP)/include/openssl/opensslconf.h > /dev/null || \
 | 
				
			||||||
		(cd ..; $(MAKE) $(SHARED_LIB)); \
 | 
							(cd ..; $(MAKE) $(SHARED_LIB)); \
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -113,7 +114,7 @@ tests:
 | 
				
			|||||||
	done;
 | 
						done;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install:
 | 
					install:
 | 
				
			||||||
	@for i in $(EXHEADER) ;\
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist ;\
 | 
				
			||||||
	do \
 | 
						do \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
@@ -200,8 +201,8 @@ mem_dbg.o: ../include/openssl/err.h ../include/openssl/lhash.h
 | 
				
			|||||||
mem_dbg.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
					mem_dbg.o: ../include/openssl/opensslconf.h ../include/openssl/opensslv.h
 | 
				
			||||||
mem_dbg.o: ../include/openssl/safestack.h ../include/openssl/stack.h
 | 
					mem_dbg.o: ../include/openssl/safestack.h ../include/openssl/stack.h
 | 
				
			||||||
mem_dbg.o: ../include/openssl/symhacks.h cryptlib.h mem_dbg.c
 | 
					mem_dbg.o: ../include/openssl/symhacks.h cryptlib.h mem_dbg.c
 | 
				
			||||||
o_str.o: ../include/openssl/e_os2.h ../include/openssl/opensslconf.h o_str.c
 | 
					o_str.o: ../e_os.h ../include/openssl/e_os2.h ../include/openssl/opensslconf.h
 | 
				
			||||||
o_str.o: o_str.h
 | 
					o_str.o: o_str.c o_str.h
 | 
				
			||||||
o_time.o: ../include/openssl/e_os2.h ../include/openssl/opensslconf.h o_time.c
 | 
					o_time.o: ../include/openssl/e_os2.h ../include/openssl/opensslconf.h o_time.c
 | 
				
			||||||
o_time.o: o_time.h
 | 
					o_time.o: o_time.h
 | 
				
			||||||
tmdiff.o: ../e_os.h ../include/openssl/bio.h ../include/openssl/buffer.h
 | 
					tmdiff.o: ../e_os.h ../include/openssl/bio.h ../include/openssl/buffer.h
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
lib
 | 
					lib
 | 
				
			||||||
Makefile.save
 | 
					Makefile.save
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -58,7 +58,7 @@ links:
 | 
				
			|||||||
install: installs
 | 
					install: installs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
installs:
 | 
					installs:
 | 
				
			||||||
	@for i in $(EXHEADER) ; \
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist ; \
 | 
				
			||||||
	do  \
 | 
						do  \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
@@ -86,8 +86,9 @@ clean:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
aes_cbc.o: ../../include/openssl/aes.h ../../include/openssl/e_os2.h
 | 
					aes_cbc.o: ../../include/openssl/aes.h ../../include/openssl/e_os2.h
 | 
				
			||||||
aes_cbc.o: ../../include/openssl/opensslconf.h aes_cbc.c aes_locl.h
 | 
					aes_cbc.o: ../../include/openssl/opensslconf.h aes_cbc.c aes_locl.h
 | 
				
			||||||
aes_cfb.o: ../../include/openssl/aes.h ../../include/openssl/e_os2.h
 | 
					aes_cfb.o: ../../e_os.h ../../include/openssl/aes.h
 | 
				
			||||||
aes_cfb.o: ../../include/openssl/opensslconf.h aes_cfb.c aes_locl.h
 | 
					aes_cfb.o: ../../include/openssl/e_os2.h ../../include/openssl/opensslconf.h
 | 
				
			||||||
 | 
					aes_cfb.o: aes_cfb.c aes_locl.h
 | 
				
			||||||
aes_core.o: ../../include/openssl/aes.h ../../include/openssl/e_os2.h
 | 
					aes_core.o: ../../include/openssl/aes.h ../../include/openssl/e_os2.h
 | 
				
			||||||
aes_core.o: ../../include/openssl/fips.h ../../include/openssl/opensslconf.h
 | 
					aes_core.o: ../../include/openssl/fips.h ../../include/openssl/opensslconf.h
 | 
				
			||||||
aes_core.o: aes_core.c aes_locl.h
 | 
					aes_core.o: aes_core.c aes_locl.h
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -59,6 +59,7 @@
 | 
				
			|||||||
#include <openssl/aes.h>
 | 
					#include <openssl/aes.h>
 | 
				
			||||||
#include "aes_locl.h"
 | 
					#include "aes_locl.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#if !defined(OPENSSL_FIPS_AES_ASM)
 | 
				
			||||||
void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
 | 
					void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
 | 
				
			||||||
		     const unsigned long length, const AES_KEY *key,
 | 
							     const unsigned long length, const AES_KEY *key,
 | 
				
			||||||
		     unsigned char *ivec, const int enc) {
 | 
							     unsigned char *ivec, const int enc) {
 | 
				
			||||||
@@ -66,6 +67,7 @@ void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
 | 
				
			|||||||
	unsigned long n;
 | 
						unsigned long n;
 | 
				
			||||||
	unsigned long len = length;
 | 
						unsigned long len = length;
 | 
				
			||||||
	unsigned char tmp[AES_BLOCK_SIZE];
 | 
						unsigned char tmp[AES_BLOCK_SIZE];
 | 
				
			||||||
 | 
						const unsigned char *iv = ivec;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	assert(in && out && key && ivec);
 | 
						assert(in && out && key && ivec);
 | 
				
			||||||
	assert((AES_ENCRYPT == enc)||(AES_DECRYPT == enc));
 | 
						assert((AES_ENCRYPT == enc)||(AES_DECRYPT == enc));
 | 
				
			||||||
@@ -73,22 +75,39 @@ void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
 | 
				
			|||||||
	if (AES_ENCRYPT == enc) {
 | 
						if (AES_ENCRYPT == enc) {
 | 
				
			||||||
		while (len >= AES_BLOCK_SIZE) {
 | 
							while (len >= AES_BLOCK_SIZE) {
 | 
				
			||||||
			for(n=0; n < AES_BLOCK_SIZE; ++n)
 | 
								for(n=0; n < AES_BLOCK_SIZE; ++n)
 | 
				
			||||||
				tmp[n] = in[n] ^ ivec[n];
 | 
									out[n] = in[n] ^ iv[n];
 | 
				
			||||||
			AES_encrypt(tmp, out, key);
 | 
								AES_encrypt(out, out, key);
 | 
				
			||||||
			memcpy(ivec, out, AES_BLOCK_SIZE);
 | 
								iv = out;
 | 
				
			||||||
			len -= AES_BLOCK_SIZE;
 | 
								len -= AES_BLOCK_SIZE;
 | 
				
			||||||
			in += AES_BLOCK_SIZE;
 | 
								in += AES_BLOCK_SIZE;
 | 
				
			||||||
			out += AES_BLOCK_SIZE;
 | 
								out += AES_BLOCK_SIZE;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		if (len) {
 | 
							if (len) {
 | 
				
			||||||
			for(n=0; n < len; ++n)
 | 
								for(n=0; n < len; ++n)
 | 
				
			||||||
				tmp[n] = in[n] ^ ivec[n];
 | 
									out[n] = in[n] ^ iv[n];
 | 
				
			||||||
			for(n=len; n < AES_BLOCK_SIZE; ++n)
 | 
								for(n=len; n < AES_BLOCK_SIZE; ++n)
 | 
				
			||||||
				tmp[n] = ivec[n];
 | 
									out[n] = iv[n];
 | 
				
			||||||
			AES_encrypt(tmp, tmp, key);
 | 
								AES_encrypt(out, out, key);
 | 
				
			||||||
			memcpy(out, tmp, AES_BLOCK_SIZE);
 | 
								iv = out;
 | 
				
			||||||
			memcpy(ivec, tmp, AES_BLOCK_SIZE);
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
							memcpy(ivec,iv,AES_BLOCK_SIZE);
 | 
				
			||||||
 | 
						} else if (in != out) {
 | 
				
			||||||
 | 
							while (len >= AES_BLOCK_SIZE) {
 | 
				
			||||||
 | 
								AES_decrypt(in, out, key);
 | 
				
			||||||
 | 
								for(n=0; n < AES_BLOCK_SIZE; ++n)
 | 
				
			||||||
 | 
									out[n] ^= iv[n];
 | 
				
			||||||
 | 
								iv = in;
 | 
				
			||||||
 | 
								len -= AES_BLOCK_SIZE;
 | 
				
			||||||
 | 
								in  += AES_BLOCK_SIZE;
 | 
				
			||||||
 | 
								out += AES_BLOCK_SIZE;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if (len) {
 | 
				
			||||||
 | 
								AES_decrypt(in,tmp,key);
 | 
				
			||||||
 | 
								for(n=0; n < len; ++n)
 | 
				
			||||||
 | 
									out[n] = tmp[n] ^ iv[n];
 | 
				
			||||||
 | 
								iv = in;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							memcpy(ivec,iv,AES_BLOCK_SIZE);
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		while (len >= AES_BLOCK_SIZE) {
 | 
							while (len >= AES_BLOCK_SIZE) {
 | 
				
			||||||
			memcpy(tmp, in, AES_BLOCK_SIZE);
 | 
								memcpy(tmp, in, AES_BLOCK_SIZE);
 | 
				
			||||||
@@ -102,10 +121,13 @@ void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		if (len) {
 | 
							if (len) {
 | 
				
			||||||
			memcpy(tmp, in, AES_BLOCK_SIZE);
 | 
								memcpy(tmp, in, AES_BLOCK_SIZE);
 | 
				
			||||||
			AES_decrypt(tmp, tmp, key);
 | 
								AES_decrypt(tmp, out, key);
 | 
				
			||||||
			for(n=0; n < len; ++n)
 | 
								for(n=0; n < len; ++n)
 | 
				
			||||||
				out[n] = tmp[n] ^ ivec[n];
 | 
									out[n] ^= ivec[n];
 | 
				
			||||||
 | 
								for(n=len; n < AES_BLOCK_SIZE; ++n)
 | 
				
			||||||
 | 
									out[n] = tmp[n];
 | 
				
			||||||
			memcpy(ivec, tmp, AES_BLOCK_SIZE);
 | 
								memcpy(ivec, tmp, AES_BLOCK_SIZE);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -114,6 +114,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include <openssl/aes.h>
 | 
					#include <openssl/aes.h>
 | 
				
			||||||
#include "aes_locl.h"
 | 
					#include "aes_locl.h"
 | 
				
			||||||
 | 
					#include "e_os.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* The input and output encrypted as though 128bit cfb mode is being
 | 
					/* The input and output encrypted as though 128bit cfb mode is being
 | 
				
			||||||
 * used.  The extra state information to record how much of the
 | 
					 * used.  The extra state information to record how much of the
 | 
				
			||||||
@@ -157,61 +158,35 @@ void AES_cfb128_encrypt(const unsigned char *in, unsigned char *out,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* This expects a single block of size nbits for both in and out. Note that
 | 
					/* This expects a single block of size nbits for both in and out. Note that
 | 
				
			||||||
   it corrupts any extra bits in the last byte of out */
 | 
					   it corrupts any extra bits in the last byte of out */
 | 
				
			||||||
/* Untested, once it is working, it will be optimised */
 | 
					 | 
				
			||||||
void AES_cfbr_encrypt_block(const unsigned char *in,unsigned char *out,
 | 
					void AES_cfbr_encrypt_block(const unsigned char *in,unsigned char *out,
 | 
				
			||||||
			    const int nbits,const AES_KEY *key,
 | 
								    const int nbits,const AES_KEY *key,
 | 
				
			||||||
			    unsigned char *ivec,const int enc)
 | 
								    unsigned char *ivec,const int enc)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
    int n;
 | 
					    int n,rem,num;
 | 
				
			||||||
    unsigned char ovec[AES_BLOCK_SIZE*2];
 | 
					    unsigned char ovec[AES_BLOCK_SIZE*2];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    assert(in && out && key && ivec);
 | 
					    if (nbits<=0 || nbits>128) return;
 | 
				
			||||||
    if(enc)
 | 
					
 | 
				
			||||||
	{
 | 
						/* fill in the first half of the new IV with the current IV */
 | 
				
			||||||
 | 
						memcpy(ovec,ivec,AES_BLOCK_SIZE);
 | 
				
			||||||
	/* construct the new IV */
 | 
						/* construct the new IV */
 | 
				
			||||||
	AES_encrypt(ivec,ovec,key);
 | 
						AES_encrypt(ivec,ivec,key);
 | 
				
			||||||
	/* encrypt the input */
 | 
						num = (nbits+7)/8;
 | 
				
			||||||
	for(n=0 ; n < (nbits+7)/8 ; ++n)
 | 
						if (enc)	/* encrypt the input */
 | 
				
			||||||
	    out[n]=in[n]^ovec[n];
 | 
						    for(n=0 ; n < num ; ++n)
 | 
				
			||||||
	/* fill in the first half of the new IV with the current IV */
 | 
							out[n] = (ovec[AES_BLOCK_SIZE+n] = in[n] ^ ivec[n]);
 | 
				
			||||||
	memcpy(ovec,ivec,AES_BLOCK_SIZE);
 | 
						else		/* decrypt the input */
 | 
				
			||||||
	/* and put the ciphertext in the second half */
 | 
						    for(n=0 ; n < num ; ++n)
 | 
				
			||||||
	memcpy(ovec+AES_BLOCK_SIZE,out,(nbits+7)/8);
 | 
							out[n] = (ovec[AES_BLOCK_SIZE+n] = in[n]) ^ ivec[n];
 | 
				
			||||||
	/* shift ovec left most of the bits... */
 | 
						/* shift ovec left... */
 | 
				
			||||||
	memmove(ovec,ovec+nbits/8,AES_BLOCK_SIZE+(nbits%8 ? 1 : 0));
 | 
						rem = nbits%8;
 | 
				
			||||||
	/* now the remaining bits */
 | 
						num = nbits/8;
 | 
				
			||||||
	if(nbits%8 != 0)
 | 
						if(rem==0)
 | 
				
			||||||
 | 
						    memcpy(ivec,ovec+num,AES_BLOCK_SIZE);
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
	    for(n=0 ; n < AES_BLOCK_SIZE ; ++n)
 | 
						    for(n=0 ; n < AES_BLOCK_SIZE ; ++n)
 | 
				
			||||||
		{
 | 
							ivec[n] = ovec[n+num]<<rem | ovec[n+num+1]>>(8-rem);
 | 
				
			||||||
		ovec[n]<<=nbits%8;
 | 
					
 | 
				
			||||||
		ovec[n]|=ovec[n+1]>>(8-nbits%8);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	/* finally, move it back into place */
 | 
					 | 
				
			||||||
	memcpy(ivec,ovec,AES_BLOCK_SIZE);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
    else
 | 
					 | 
				
			||||||
	{
 | 
					 | 
				
			||||||
	/* construct the new IV in the first half of ovec */
 | 
					 | 
				
			||||||
	AES_encrypt(ivec,ovec,key);
 | 
					 | 
				
			||||||
	/* decrypt the input */
 | 
					 | 
				
			||||||
	for(n=0 ; n < (nbits+7)/8 ; ++n)
 | 
					 | 
				
			||||||
	    out[n]=in[n]^ovec[n];
 | 
					 | 
				
			||||||
	/* fill in the first half of the new IV with the current IV */
 | 
					 | 
				
			||||||
	memcpy(ovec,ivec,AES_BLOCK_SIZE);
 | 
					 | 
				
			||||||
	/* append the ciphertext */
 | 
					 | 
				
			||||||
	memcpy(ovec+AES_BLOCK_SIZE,in,(nbits+7)/8);
 | 
					 | 
				
			||||||
	/* shift ovec left most of the bits... */
 | 
					 | 
				
			||||||
	memmove(ovec,ovec+nbits/8,AES_BLOCK_SIZE+(nbits%8 ? 1 : 0));
 | 
					 | 
				
			||||||
	/* now the remaining bits */
 | 
					 | 
				
			||||||
	if(nbits%8 != 0)
 | 
					 | 
				
			||||||
	    for(n=0 ; n < AES_BLOCK_SIZE ; ++n)
 | 
					 | 
				
			||||||
		{
 | 
					 | 
				
			||||||
		ovec[n]<<=nbits%8;
 | 
					 | 
				
			||||||
		ovec[n]|=ovec[n+1]>>(8-nbits%8);
 | 
					 | 
				
			||||||
		}
 | 
					 | 
				
			||||||
	/* finally, move it back into place */
 | 
					 | 
				
			||||||
	memcpy(ivec,ovec,AES_BLOCK_SIZE);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
    /* it is not necessary to cleanse ovec, since the IV is not secret */
 | 
					    /* it is not necessary to cleanse ovec, since the IV is not secret */
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
lib
 | 
					lib
 | 
				
			||||||
Makefile.save
 | 
					Makefile.save
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -81,7 +81,7 @@ links:
 | 
				
			|||||||
	@$(PERL) $(TOP)/util/mklink.pl ../../apps $(APPS)
 | 
						@$(PERL) $(TOP)/util/mklink.pl ../../apps $(APPS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install:
 | 
					install:
 | 
				
			||||||
	@for i in $(EXHEADER) ; \
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist ; \
 | 
				
			||||||
	do  \
 | 
						do  \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -194,8 +194,12 @@ int ASN1_BIT_STRING_set_bit(ASN1_BIT_STRING *a, int n, int value)
 | 
				
			|||||||
			c=(unsigned char *)OPENSSL_realloc_clean(a->data,
 | 
								c=(unsigned char *)OPENSSL_realloc_clean(a->data,
 | 
				
			||||||
								 a->length,
 | 
													 a->length,
 | 
				
			||||||
								 w+1);
 | 
													 w+1);
 | 
				
			||||||
		if (c == NULL) return(0);
 | 
							if (c == NULL)
 | 
				
			||||||
		if (w+1-a->length > 0) memset(c+a->length, 0, w+1-a->length);
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_ASN1_BIT_STRING_SET_BIT,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								return 0;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					  		if (w+1-a->length > 0) memset(c+a->length, 0, w+1-a->length);
 | 
				
			||||||
		a->data=c;
 | 
							a->data=c;
 | 
				
			||||||
		a->length=w+1;
 | 
							a->length=w+1;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -65,6 +65,7 @@
 | 
				
			|||||||
# include <sys/types.h>
 | 
					# include <sys/types.h>
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <openssl/err.h>
 | 
				
			||||||
#include <openssl/evp.h>
 | 
					#include <openssl/evp.h>
 | 
				
			||||||
#include <openssl/buffer.h>
 | 
					#include <openssl/buffer.h>
 | 
				
			||||||
#include <openssl/x509.h>
 | 
					#include <openssl/x509.h>
 | 
				
			||||||
@@ -78,7 +79,11 @@ int ASN1_digest(int (*i2d)(), const EVP_MD *type, char *data,
 | 
				
			|||||||
	unsigned char *str,*p;
 | 
						unsigned char *str,*p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	i=i2d(data,NULL);
 | 
						i=i2d(data,NULL);
 | 
				
			||||||
	if ((str=(unsigned char *)OPENSSL_malloc(i)) == NULL) return(0);
 | 
						if ((str=(unsigned char *)OPENSSL_malloc(i)) == NULL)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ASN1err(ASN1_F_ASN1_DIGEST,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
							return(0);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	p=str;
 | 
						p=str;
 | 
				
			||||||
	i2d(data,&p);
 | 
						i2d(data,&p);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -156,7 +156,7 @@ ASN1_ENUMERATED *BN_to_ASN1_ENUMERATED(BIGNUM *bn, ASN1_ENUMERATED *ai)
 | 
				
			|||||||
		unsigned char *new_data=OPENSSL_realloc(ret->data, len+4);
 | 
							unsigned char *new_data=OPENSSL_realloc(ret->data, len+4);
 | 
				
			||||||
		if (!new_data)
 | 
							if (!new_data)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ASN1err(ASN1_F_BN_TO_ASN1_INTEGER,ERR_R_MALLOC_FAILURE);
 | 
								ASN1err(ASN1_F_BN_TO_ASN1_ENUMERATED,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
			goto err;
 | 
								goto err;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		ret->data=new_data;
 | 
							ret->data=new_data;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -192,8 +192,9 @@ int ASN1_GENERALIZEDTIME_set_string(ASN1_GENERALIZEDTIME *s, char *str)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (s != NULL)
 | 
							if (s != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ASN1_STRING_set((ASN1_STRING *)s,
 | 
								if (!ASN1_STRING_set((ASN1_STRING *)s,
 | 
				
			||||||
				(unsigned char *)str,t.length);
 | 
									(unsigned char *)str,t.length))
 | 
				
			||||||
 | 
									return 0;
 | 
				
			||||||
			s->type=V_ASN1_GENERALIZEDTIME;
 | 
								s->type=V_ASN1_GENERALIZEDTIME;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		return(1);
 | 
							return(1);
 | 
				
			||||||
@@ -223,7 +224,12 @@ ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_set(ASN1_GENERALIZEDTIME *s,
 | 
				
			|||||||
	if ((p == NULL) || ((size_t)s->length < len))
 | 
						if ((p == NULL) || ((size_t)s->length < len))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		p=OPENSSL_malloc(len);
 | 
							p=OPENSSL_malloc(len);
 | 
				
			||||||
		if (p == NULL) return(NULL);
 | 
							if (p == NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_ASN1_GENERALIZEDTIME_SET,
 | 
				
			||||||
 | 
									ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								return(NULL);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		if (s->data != NULL)
 | 
							if (s->data != NULL)
 | 
				
			||||||
			OPENSSL_free(s->data);
 | 
								OPENSSL_free(s->data);
 | 
				
			||||||
		s->data=(unsigned char *)p;
 | 
							s->data=(unsigned char *)p;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -60,7 +60,7 @@
 | 
				
			|||||||
#include "cryptlib.h"
 | 
					#include "cryptlib.h"
 | 
				
			||||||
#include <openssl/asn1.h>
 | 
					#include <openssl/asn1.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int ASN1_PRINTABLE_type(unsigned char *s, int len)
 | 
					int ASN1_PRINTABLE_type(const unsigned char *s, int len)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int c;
 | 
						int c;
 | 
				
			||||||
	int ia5=0;
 | 
						int ia5=0;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -118,8 +118,13 @@ int i2d_ASN1_SET(STACK *a, unsigned char **pp, int (*func)(), int ex_tag,
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        pStart  = p; /* Catch the beg of Setblobs*/
 | 
					        pStart  = p; /* Catch the beg of Setblobs*/
 | 
				
			||||||
        if (!(rgSetBlob = (MYBLOB *)OPENSSL_malloc( sk_num(a) * sizeof(MYBLOB)))) return 0; /* In this array
 | 
							/* In this array we will store the SET blobs */
 | 
				
			||||||
we will store the SET blobs */
 | 
							rgSetBlob = (MYBLOB *)OPENSSL_malloc(sk_num(a) * sizeof(MYBLOB));
 | 
				
			||||||
 | 
							if (rgSetBlob == NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_I2D_ASN1_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								return(0);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        for (i=0; i<sk_num(a); i++)
 | 
					        for (i=0; i<sk_num(a); i++)
 | 
				
			||||||
	        {
 | 
						        {
 | 
				
			||||||
@@ -135,7 +140,11 @@ SetBlob
 | 
				
			|||||||
 /* Now we have to sort the blobs. I am using a simple algo.
 | 
					 /* Now we have to sort the blobs. I am using a simple algo.
 | 
				
			||||||
    *Sort ptrs *Copy to temp-mem *Copy from temp-mem to user-mem*/
 | 
					    *Sort ptrs *Copy to temp-mem *Copy from temp-mem to user-mem*/
 | 
				
			||||||
        qsort( rgSetBlob, sk_num(a), sizeof(MYBLOB), SetBlobCmp);
 | 
					        qsort( rgSetBlob, sk_num(a), sizeof(MYBLOB), SetBlobCmp);
 | 
				
			||||||
        if (!(pTempMem = OPENSSL_malloc(totSize))) return 0;
 | 
							if (!(pTempMem = OPENSSL_malloc(totSize)))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_I2D_ASN1_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								return(0);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* Copy to temp mem */
 | 
					/* Copy to temp mem */
 | 
				
			||||||
        p = pTempMem;
 | 
					        p = pTempMem;
 | 
				
			||||||
@@ -160,7 +169,13 @@ STACK *d2i_ASN1_SET(STACK **a, unsigned char **pp, long length,
 | 
				
			|||||||
	STACK *ret=NULL;
 | 
						STACK *ret=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((a == NULL) || ((*a) == NULL))
 | 
						if ((a == NULL) || ((*a) == NULL))
 | 
				
			||||||
		{ if ((ret=sk_new_null()) == NULL) goto err; }
 | 
							{
 | 
				
			||||||
 | 
							if ((ret=sk_new_null()) == NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_D2I_ASN1_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								goto err;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		ret=(*a);
 | 
							ret=(*a);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -71,7 +71,10 @@ int ASN1_TYPE_get(ASN1_TYPE *a)
 | 
				
			|||||||
void ASN1_TYPE_set(ASN1_TYPE *a, int type, void *value)
 | 
					void ASN1_TYPE_set(ASN1_TYPE *a, int type, void *value)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	if (a->value.ptr != NULL)
 | 
						if (a->value.ptr != NULL)
 | 
				
			||||||
		ASN1_primitive_free((ASN1_VALUE **)&a, NULL);
 | 
							{
 | 
				
			||||||
 | 
							ASN1_TYPE **tmp_a = &a;
 | 
				
			||||||
 | 
							ASN1_primitive_free((ASN1_VALUE **)tmp_a, NULL);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	a->type=type;
 | 
						a->type=type;
 | 
				
			||||||
	a->value.ptr=value;
 | 
						a->value.ptr=value;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -173,8 +173,9 @@ int ASN1_UTCTIME_set_string(ASN1_UTCTIME *s, char *str)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		if (s != NULL)
 | 
							if (s != NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ASN1_STRING_set((ASN1_STRING *)s,
 | 
								if (!ASN1_STRING_set((ASN1_STRING *)s,
 | 
				
			||||||
				(unsigned char *)str,t.length);
 | 
									(unsigned char *)str,t.length))
 | 
				
			||||||
 | 
									return 0;
 | 
				
			||||||
			s->type = V_ASN1_UTCTIME;
 | 
								s->type = V_ASN1_UTCTIME;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		return(1);
 | 
							return(1);
 | 
				
			||||||
@@ -203,7 +204,11 @@ ASN1_UTCTIME *ASN1_UTCTIME_set(ASN1_UTCTIME *s, time_t t)
 | 
				
			|||||||
	if ((p == NULL) || ((size_t)s->length < len))
 | 
						if ((p == NULL) || ((size_t)s->length < len))
 | 
				
			||||||
		{
 | 
							{
 | 
				
			||||||
		p=OPENSSL_malloc(len);
 | 
							p=OPENSSL_malloc(len);
 | 
				
			||||||
		if (p == NULL) return(NULL);
 | 
							if (p == NULL)
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_ASN1_UTCTIME_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								return(NULL);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		if (s->data != NULL)
 | 
							if (s->data != NULL)
 | 
				
			||||||
			OPENSSL_free(s->data);
 | 
								OPENSSL_free(s->data);
 | 
				
			||||||
		s->data=(unsigned char *)p;
 | 
							s->data=(unsigned char *)p;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -142,6 +142,13 @@ int ASN1_item_verify(const ASN1_ITEM *it, X509_ALGOR *a, ASN1_BIT_STRING *signat
 | 
				
			|||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!EVP_VerifyInit_ex(&ctx,type, NULL))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ASN1err(ASN1_F_ASN1_VERIFY,ERR_R_EVP_LIB);
 | 
				
			||||||
 | 
							ret=0;
 | 
				
			||||||
 | 
							goto err;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	inl = ASN1_item_i2d(asn, &buf_in, it);
 | 
						inl = ASN1_item_i2d(asn, &buf_in, it);
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	if (buf_in == NULL)
 | 
						if (buf_in == NULL)
 | 
				
			||||||
@@ -150,7 +157,6 @@ int ASN1_item_verify(const ASN1_ITEM *it, X509_ALGOR *a, ASN1_BIT_STRING *signat
 | 
				
			|||||||
		goto err;
 | 
							goto err;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	EVP_VerifyInit_ex(&ctx,type, NULL);
 | 
					 | 
				
			||||||
	EVP_VerifyUpdate(&ctx,(unsigned char *)buf_in,inl);
 | 
						EVP_VerifyUpdate(&ctx,(unsigned char *)buf_in,inl);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	OPENSSL_cleanse(buf_in,(unsigned int)inl);
 | 
						OPENSSL_cleanse(buf_in,(unsigned int)inl);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -829,7 +829,7 @@ BIGNUM *ASN1_ENUMERATED_to_BN(ASN1_ENUMERATED *ai,BIGNUM *bn);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* General */
 | 
					/* General */
 | 
				
			||||||
/* given a string, return the correct type, max is the maximum length */
 | 
					/* given a string, return the correct type, max is the maximum length */
 | 
				
			||||||
int ASN1_PRINTABLE_type(unsigned char *s, int max);
 | 
					int ASN1_PRINTABLE_type(const unsigned char *s, int max);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
int i2d_ASN1_bytes(ASN1_STRING *a, unsigned char **pp, int tag, int xclass);
 | 
					int i2d_ASN1_bytes(ASN1_STRING *a, unsigned char **pp, int tag, int xclass);
 | 
				
			||||||
ASN1_STRING *d2i_ASN1_bytes(ASN1_STRING **a, unsigned char **pp,
 | 
					ASN1_STRING *d2i_ASN1_bytes(ASN1_STRING **a, unsigned char **pp,
 | 
				
			||||||
@@ -950,16 +950,20 @@ void ERR_load_ASN1_strings(void);
 | 
				
			|||||||
#define ASN1_F_A2I_ASN1_ENUMERATED			 101
 | 
					#define ASN1_F_A2I_ASN1_ENUMERATED			 101
 | 
				
			||||||
#define ASN1_F_A2I_ASN1_INTEGER				 102
 | 
					#define ASN1_F_A2I_ASN1_INTEGER				 102
 | 
				
			||||||
#define ASN1_F_A2I_ASN1_STRING				 103
 | 
					#define ASN1_F_A2I_ASN1_STRING				 103
 | 
				
			||||||
 | 
					#define ASN1_F_ASN1_BIT_STRING_SET_BIT			 176
 | 
				
			||||||
#define ASN1_F_ASN1_CHECK_TLEN				 104
 | 
					#define ASN1_F_ASN1_CHECK_TLEN				 104
 | 
				
			||||||
#define ASN1_F_ASN1_COLLATE_PRIMITIVE			 105
 | 
					#define ASN1_F_ASN1_COLLATE_PRIMITIVE			 105
 | 
				
			||||||
#define ASN1_F_ASN1_COLLECT				 106
 | 
					#define ASN1_F_ASN1_COLLECT				 106
 | 
				
			||||||
#define ASN1_F_ASN1_D2I_BIO				 107
 | 
					#define ASN1_F_ASN1_D2I_BIO				 107
 | 
				
			||||||
#define ASN1_F_ASN1_D2I_EX_PRIMITIVE			 108
 | 
					#define ASN1_F_ASN1_D2I_EX_PRIMITIVE			 108
 | 
				
			||||||
#define ASN1_F_ASN1_D2I_FP				 109
 | 
					#define ASN1_F_ASN1_D2I_FP				 109
 | 
				
			||||||
 | 
					#define ASN1_F_ASN1_DIGEST				 177
 | 
				
			||||||
#define ASN1_F_ASN1_DO_ADB				 110
 | 
					#define ASN1_F_ASN1_DO_ADB				 110
 | 
				
			||||||
#define ASN1_F_ASN1_DUP					 111
 | 
					#define ASN1_F_ASN1_DUP					 111
 | 
				
			||||||
#define ASN1_F_ASN1_ENUMERATED_SET			 112
 | 
					#define ASN1_F_ASN1_ENUMERATED_SET			 112
 | 
				
			||||||
#define ASN1_F_ASN1_ENUMERATED_TO_BN			 113
 | 
					#define ASN1_F_ASN1_ENUMERATED_TO_BN			 113
 | 
				
			||||||
 | 
					#define ASN1_F_ASN1_FIND_END				 182
 | 
				
			||||||
 | 
					#define ASN1_F_ASN1_GENERALIZEDTIME_SET			 178
 | 
				
			||||||
#define ASN1_F_ASN1_GET_OBJECT				 114
 | 
					#define ASN1_F_ASN1_GET_OBJECT				 114
 | 
				
			||||||
#define ASN1_F_ASN1_HEADER_NEW				 115
 | 
					#define ASN1_F_ASN1_HEADER_NEW				 115
 | 
				
			||||||
#define ASN1_F_ASN1_I2D_BIO				 116
 | 
					#define ASN1_F_ASN1_I2D_BIO				 116
 | 
				
			||||||
@@ -975,6 +979,7 @@ void ERR_load_ASN1_strings(void);
 | 
				
			|||||||
#define ASN1_F_ASN1_SEQ_PACK				 126
 | 
					#define ASN1_F_ASN1_SEQ_PACK				 126
 | 
				
			||||||
#define ASN1_F_ASN1_SEQ_UNPACK				 127
 | 
					#define ASN1_F_ASN1_SEQ_UNPACK				 127
 | 
				
			||||||
#define ASN1_F_ASN1_SIGN				 128
 | 
					#define ASN1_F_ASN1_SIGN				 128
 | 
				
			||||||
 | 
					#define ASN1_F_ASN1_STRING_SET				 179
 | 
				
			||||||
#define ASN1_F_ASN1_STRING_TABLE_ADD			 129
 | 
					#define ASN1_F_ASN1_STRING_TABLE_ADD			 129
 | 
				
			||||||
#define ASN1_F_ASN1_STRING_TYPE_NEW			 130
 | 
					#define ASN1_F_ASN1_STRING_TYPE_NEW			 130
 | 
				
			||||||
#define ASN1_F_ASN1_TEMPLATE_D2I			 131
 | 
					#define ASN1_F_ASN1_TEMPLATE_D2I			 131
 | 
				
			||||||
@@ -984,6 +989,7 @@ void ERR_load_ASN1_strings(void);
 | 
				
			|||||||
#define ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING		 134
 | 
					#define ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING		 134
 | 
				
			||||||
#define ASN1_F_ASN1_TYPE_GET_OCTETSTRING		 135
 | 
					#define ASN1_F_ASN1_TYPE_GET_OCTETSTRING		 135
 | 
				
			||||||
#define ASN1_F_ASN1_UNPACK_STRING			 136
 | 
					#define ASN1_F_ASN1_UNPACK_STRING			 136
 | 
				
			||||||
 | 
					#define ASN1_F_ASN1_UTCTIME_SET				 180
 | 
				
			||||||
#define ASN1_F_ASN1_VERIFY				 137
 | 
					#define ASN1_F_ASN1_VERIFY				 137
 | 
				
			||||||
#define ASN1_F_BN_TO_ASN1_ENUMERATED			 138
 | 
					#define ASN1_F_BN_TO_ASN1_ENUMERATED			 138
 | 
				
			||||||
#define ASN1_F_BN_TO_ASN1_INTEGER			 139
 | 
					#define ASN1_F_BN_TO_ASN1_INTEGER			 139
 | 
				
			||||||
@@ -1007,6 +1013,7 @@ void ERR_load_ASN1_strings(void);
 | 
				
			|||||||
#define ASN1_F_D2I_X509_CINF				 157
 | 
					#define ASN1_F_D2I_X509_CINF				 157
 | 
				
			||||||
#define ASN1_F_D2I_X509_NAME				 158
 | 
					#define ASN1_F_D2I_X509_NAME				 158
 | 
				
			||||||
#define ASN1_F_D2I_X509_PKEY				 159
 | 
					#define ASN1_F_D2I_X509_PKEY				 159
 | 
				
			||||||
 | 
					#define ASN1_F_I2D_ASN1_SET				 181
 | 
				
			||||||
#define ASN1_F_I2D_ASN1_TIME				 160
 | 
					#define ASN1_F_I2D_ASN1_TIME				 160
 | 
				
			||||||
#define ASN1_F_I2D_DSA_PUBKEY				 161
 | 
					#define ASN1_F_I2D_DSA_PUBKEY				 161
 | 
				
			||||||
#define ASN1_F_I2D_NETSCAPE_RSA				 162
 | 
					#define ASN1_F_I2D_NETSCAPE_RSA				 162
 | 
				
			||||||
@@ -1069,6 +1076,7 @@ void ERR_load_ASN1_strings(void);
 | 
				
			|||||||
#define ASN1_R_MISSING_SECOND_NUMBER			 138
 | 
					#define ASN1_R_MISSING_SECOND_NUMBER			 138
 | 
				
			||||||
#define ASN1_R_MSTRING_NOT_UNIVERSAL			 139
 | 
					#define ASN1_R_MSTRING_NOT_UNIVERSAL			 139
 | 
				
			||||||
#define ASN1_R_MSTRING_WRONG_TAG			 140
 | 
					#define ASN1_R_MSTRING_WRONG_TAG			 140
 | 
				
			||||||
 | 
					#define ASN1_R_NESTED_ASN1_STRING			 174
 | 
				
			||||||
#define ASN1_R_NON_HEX_CHARACTERS			 141
 | 
					#define ASN1_R_NON_HEX_CHARACTERS			 141
 | 
				
			||||||
#define ASN1_R_NOT_ENOUGH_DATA				 142
 | 
					#define ASN1_R_NOT_ENOUGH_DATA				 142
 | 
				
			||||||
#define ASN1_R_NO_MATCHING_CHOICE_TYPE			 143
 | 
					#define ASN1_R_NO_MATCHING_CHOICE_TYPE			 143
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
/* crypto/asn1/asn1_err.c */
 | 
					/* crypto/asn1/asn1_err.c */
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 1999-2002 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1999-2005 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
 | 
				
			||||||
@@ -64,163 +64,175 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* BEGIN ERROR CODES */
 | 
					/* BEGIN ERROR CODES */
 | 
				
			||||||
#ifndef OPENSSL_NO_ERR
 | 
					#ifndef OPENSSL_NO_ERR
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define ERR_FUNC(func) ERR_PACK(ERR_LIB_ASN1,func,0)
 | 
				
			||||||
 | 
					#define ERR_REASON(reason) ERR_PACK(ERR_LIB_ASN1,0,reason)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static ERR_STRING_DATA ASN1_str_functs[]=
 | 
					static ERR_STRING_DATA ASN1_str_functs[]=
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_A2D_ASN1_OBJECT,0),	"a2d_ASN1_OBJECT"},
 | 
					{ERR_FUNC(ASN1_F_A2D_ASN1_OBJECT),	"a2d_ASN1_OBJECT"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_A2I_ASN1_ENUMERATED,0),	"a2i_ASN1_ENUMERATED"},
 | 
					{ERR_FUNC(ASN1_F_A2I_ASN1_ENUMERATED),	"a2i_ASN1_ENUMERATED"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_A2I_ASN1_INTEGER,0),	"a2i_ASN1_INTEGER"},
 | 
					{ERR_FUNC(ASN1_F_A2I_ASN1_INTEGER),	"a2i_ASN1_INTEGER"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_A2I_ASN1_STRING,0),	"a2i_ASN1_STRING"},
 | 
					{ERR_FUNC(ASN1_F_A2I_ASN1_STRING),	"a2i_ASN1_STRING"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_CHECK_TLEN,0),	"ASN1_CHECK_TLEN"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_BIT_STRING_SET_BIT),	"ASN1_BIT_STRING_set_bit"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_COLLATE_PRIMITIVE,0),	"ASN1_COLLATE_PRIMITIVE"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_CHECK_TLEN),	"ASN1_CHECK_TLEN"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_COLLECT,0),	"ASN1_COLLECT"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_COLLATE_PRIMITIVE),	"ASN1_COLLATE_PRIMITIVE"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_D2I_BIO,0),	"ASN1_d2i_bio"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_COLLECT),	"ASN1_COLLECT"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_D2I_EX_PRIMITIVE,0),	"ASN1_D2I_EX_PRIMITIVE"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_D2I_BIO),	"ASN1_d2i_bio"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_D2I_FP,0),	"ASN1_d2i_fp"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_D2I_EX_PRIMITIVE),	"ASN1_D2I_EX_PRIMITIVE"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_DO_ADB,0),	"ASN1_DO_ADB"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_D2I_FP),	"ASN1_d2i_fp"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_DUP,0),	"ASN1_dup"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_DIGEST),	"ASN1_digest"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_ENUMERATED_SET,0),	"ASN1_ENUMERATED_set"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_DO_ADB),	"ASN1_DO_ADB"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_ENUMERATED_TO_BN,0),	"ASN1_ENUMERATED_to_BN"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_DUP),	"ASN1_dup"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_GET_OBJECT,0),	"ASN1_get_object"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_ENUMERATED_SET),	"ASN1_ENUMERATED_set"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_HEADER_NEW,0),	"ASN1_HEADER_new"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_ENUMERATED_TO_BN),	"ASN1_ENUMERATED_to_BN"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_I2D_BIO,0),	"ASN1_i2d_bio"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_FIND_END),	"ASN1_FIND_END"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_I2D_FP,0),	"ASN1_i2d_fp"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_GENERALIZEDTIME_SET),	"ASN1_GENERALIZEDTIME_set"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_INTEGER_SET,0),	"ASN1_INTEGER_set"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_GET_OBJECT),	"ASN1_get_object"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_INTEGER_TO_BN,0),	"ASN1_INTEGER_to_BN"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_HEADER_NEW),	"ASN1_HEADER_new"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_ITEM_EX_D2I,0),	"ASN1_ITEM_EX_D2I"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_I2D_BIO),	"ASN1_i2d_bio"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_ITEM_NEW,0),	"ASN1_item_new"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_I2D_FP),	"ASN1_i2d_fp"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_MBSTRING_COPY,0),	"ASN1_mbstring_copy"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_INTEGER_SET),	"ASN1_INTEGER_set"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_OBJECT_NEW,0),	"ASN1_OBJECT_new"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_INTEGER_TO_BN),	"ASN1_INTEGER_to_BN"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_PACK_STRING,0),	"ASN1_pack_string"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_ITEM_EX_D2I),	"ASN1_ITEM_EX_D2I"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_PBE_SET,0),	"ASN1_PBE_SET"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_ITEM_NEW),	"ASN1_item_new"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_SEQ_PACK,0),	"ASN1_seq_pack"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_MBSTRING_COPY),	"ASN1_mbstring_copy"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_SEQ_UNPACK,0),	"ASN1_seq_unpack"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_OBJECT_NEW),	"ASN1_OBJECT_new"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_SIGN,0),	"ASN1_sign"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_PACK_STRING),	"ASN1_pack_string"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_STRING_TABLE_ADD,0),	"ASN1_STRING_TABLE_add"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_PBE_SET),	"ASN1_PBE_SET"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_STRING_TYPE_NEW,0),	"ASN1_STRING_type_new"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_SEQ_PACK),	"ASN1_seq_pack"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_D2I,0),	"ASN1_TEMPLATE_D2I"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_SEQ_UNPACK),	"ASN1_seq_unpack"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_EX_D2I,0),	"ASN1_TEMPLATE_EX_D2I"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_SIGN),	"ASN1_sign"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_NEW,0),	"ASN1_TEMPLATE_NEW"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_STRING_SET),	"ASN1_STRING_set"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_TIME_SET,0),	"ASN1_TIME_set"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_STRING_TABLE_ADD),	"ASN1_STRING_TABLE_add"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING,0),	"ASN1_TYPE_get_int_octetstring"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_STRING_TYPE_NEW),	"ASN1_STRING_type_new"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_TYPE_GET_OCTETSTRING,0),	"ASN1_TYPE_get_octetstring"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_TEMPLATE_D2I),	"ASN1_TEMPLATE_D2I"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_UNPACK_STRING,0),	"ASN1_unpack_string"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_TEMPLATE_EX_D2I),	"ASN1_TEMPLATE_EX_D2I"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_ASN1_VERIFY,0),	"ASN1_verify"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_TEMPLATE_NEW),	"ASN1_TEMPLATE_NEW"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_BN_TO_ASN1_ENUMERATED,0),	"BN_to_ASN1_ENUMERATED"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_TIME_SET),	"ASN1_TIME_set"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_BN_TO_ASN1_INTEGER,0),	"BN_to_ASN1_INTEGER"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING),	"ASN1_TYPE_get_int_octetstring"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_COLLECT_DATA,0),	"COLLECT_DATA"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_TYPE_GET_OCTETSTRING),	"ASN1_TYPE_get_octetstring"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_BIT_STRING,0),	"D2I_ASN1_BIT_STRING"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_UNPACK_STRING),	"ASN1_unpack_string"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_BOOLEAN,0),	"d2i_ASN1_BOOLEAN"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_UTCTIME_SET),	"ASN1_UTCTIME_set"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_BYTES,0),	"d2i_ASN1_bytes"},
 | 
					{ERR_FUNC(ASN1_F_ASN1_VERIFY),	"ASN1_verify"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_GENERALIZEDTIME,0),	"D2I_ASN1_GENERALIZEDTIME"},
 | 
					{ERR_FUNC(ASN1_F_BN_TO_ASN1_ENUMERATED),	"BN_to_ASN1_ENUMERATED"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_HEADER,0),	"d2i_ASN1_HEADER"},
 | 
					{ERR_FUNC(ASN1_F_BN_TO_ASN1_INTEGER),	"BN_to_ASN1_INTEGER"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_INTEGER,0),	"D2I_ASN1_INTEGER"},
 | 
					{ERR_FUNC(ASN1_F_COLLECT_DATA),	"COLLECT_DATA"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_OBJECT,0),	"d2i_ASN1_OBJECT"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_BIT_STRING),	"D2I_ASN1_BIT_STRING"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_SET,0),	"d2i_ASN1_SET"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_BOOLEAN),	"d2i_ASN1_BOOLEAN"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_TYPE_BYTES,0),	"d2i_ASN1_type_bytes"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_BYTES),	"d2i_ASN1_bytes"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_UINTEGER,0),	"d2i_ASN1_UINTEGER"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_GENERALIZEDTIME),	"D2I_ASN1_GENERALIZEDTIME"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_ASN1_UTCTIME,0),	"D2I_ASN1_UTCTIME"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_HEADER),	"d2i_ASN1_HEADER"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_NETSCAPE_RSA,0),	"d2i_Netscape_RSA"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_INTEGER),	"D2I_ASN1_INTEGER"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_NETSCAPE_RSA_2,0),	"D2I_NETSCAPE_RSA_2"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_OBJECT),	"d2i_ASN1_OBJECT"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_PRIVATEKEY,0),	"d2i_PrivateKey"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_SET),	"d2i_ASN1_SET"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_PUBLICKEY,0),	"d2i_PublicKey"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_TYPE_BYTES),	"d2i_ASN1_type_bytes"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_X509,0),	"D2I_X509"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_UINTEGER),	"d2i_ASN1_UINTEGER"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_X509_CINF,0),	"D2I_X509_CINF"},
 | 
					{ERR_FUNC(ASN1_F_D2I_ASN1_UTCTIME),	"D2I_ASN1_UTCTIME"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_X509_NAME,0),	"D2I_X509_NAME"},
 | 
					{ERR_FUNC(ASN1_F_D2I_NETSCAPE_RSA),	"d2i_Netscape_RSA"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_D2I_X509_PKEY,0),	"d2i_X509_PKEY"},
 | 
					{ERR_FUNC(ASN1_F_D2I_NETSCAPE_RSA_2),	"D2I_NETSCAPE_RSA_2"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_I2D_ASN1_TIME,0),	"I2D_ASN1_TIME"},
 | 
					{ERR_FUNC(ASN1_F_D2I_PRIVATEKEY),	"d2i_PrivateKey"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_I2D_DSA_PUBKEY,0),	"i2d_DSA_PUBKEY"},
 | 
					{ERR_FUNC(ASN1_F_D2I_PUBLICKEY),	"d2i_PublicKey"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_I2D_NETSCAPE_RSA,0),	"i2d_Netscape_RSA"},
 | 
					{ERR_FUNC(ASN1_F_D2I_X509),	"D2I_X509"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_I2D_PRIVATEKEY,0),	"i2d_PrivateKey"},
 | 
					{ERR_FUNC(ASN1_F_D2I_X509_CINF),	"D2I_X509_CINF"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_I2D_PUBLICKEY,0),	"i2d_PublicKey"},
 | 
					{ERR_FUNC(ASN1_F_D2I_X509_NAME),	"D2I_X509_NAME"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_I2D_RSA_PUBKEY,0),	"i2d_RSA_PUBKEY"},
 | 
					{ERR_FUNC(ASN1_F_D2I_X509_PKEY),	"d2i_X509_PKEY"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_LONG_C2I,0),	"LONG_C2I"},
 | 
					{ERR_FUNC(ASN1_F_I2D_ASN1_SET),	"i2d_ASN1_SET"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_OID_MODULE_INIT,0),	"OID_MODULE_INIT"},
 | 
					{ERR_FUNC(ASN1_F_I2D_ASN1_TIME),	"I2D_ASN1_TIME"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_PKCS5_PBE2_SET,0),	"PKCS5_pbe2_set"},
 | 
					{ERR_FUNC(ASN1_F_I2D_DSA_PUBKEY),	"i2d_DSA_PUBKEY"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_X509_CINF_NEW,0),	"X509_CINF_NEW"},
 | 
					{ERR_FUNC(ASN1_F_I2D_NETSCAPE_RSA),	"i2d_Netscape_RSA"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_X509_CRL_ADD0_REVOKED,0),	"X509_CRL_add0_revoked"},
 | 
					{ERR_FUNC(ASN1_F_I2D_PRIVATEKEY),	"i2d_PrivateKey"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_X509_INFO_NEW,0),	"X509_INFO_new"},
 | 
					{ERR_FUNC(ASN1_F_I2D_PUBLICKEY),	"i2d_PublicKey"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_X509_NAME_NEW,0),	"X509_NAME_NEW"},
 | 
					{ERR_FUNC(ASN1_F_I2D_RSA_PUBKEY),	"i2d_RSA_PUBKEY"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_X509_NEW,0),	"X509_NEW"},
 | 
					{ERR_FUNC(ASN1_F_LONG_C2I),	"LONG_C2I"},
 | 
				
			||||||
{ERR_PACK(0,ASN1_F_X509_PKEY_NEW,0),	"X509_PKEY_new"},
 | 
					{ERR_FUNC(ASN1_F_OID_MODULE_INIT),	"OID_MODULE_INIT"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_PKCS5_PBE2_SET),	"PKCS5_pbe2_set"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_X509_CINF_NEW),	"X509_CINF_NEW"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_X509_CRL_ADD0_REVOKED),	"X509_CRL_add0_revoked"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_X509_INFO_NEW),	"X509_INFO_new"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_X509_NAME_NEW),	"X509_NAME_NEW"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_X509_NEW),	"X509_NEW"},
 | 
				
			||||||
 | 
					{ERR_FUNC(ASN1_F_X509_PKEY_NEW),	"X509_PKEY_new"},
 | 
				
			||||||
{0,NULL}
 | 
					{0,NULL}
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static ERR_STRING_DATA ASN1_str_reasons[]=
 | 
					static ERR_STRING_DATA ASN1_str_reasons[]=
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
{ASN1_R_ADDING_OBJECT                    ,"adding object"},
 | 
					{ERR_REASON(ASN1_R_ADDING_OBJECT)        ,"adding object"},
 | 
				
			||||||
{ASN1_R_AUX_ERROR                        ,"aux error"},
 | 
					{ERR_REASON(ASN1_R_AUX_ERROR)            ,"aux error"},
 | 
				
			||||||
{ASN1_R_BAD_CLASS                        ,"bad class"},
 | 
					{ERR_REASON(ASN1_R_BAD_CLASS)            ,"bad class"},
 | 
				
			||||||
{ASN1_R_BAD_OBJECT_HEADER                ,"bad object header"},
 | 
					{ERR_REASON(ASN1_R_BAD_OBJECT_HEADER)    ,"bad object header"},
 | 
				
			||||||
{ASN1_R_BAD_PASSWORD_READ                ,"bad password read"},
 | 
					{ERR_REASON(ASN1_R_BAD_PASSWORD_READ)    ,"bad password read"},
 | 
				
			||||||
{ASN1_R_BAD_TAG                          ,"bad tag"},
 | 
					{ERR_REASON(ASN1_R_BAD_TAG)              ,"bad tag"},
 | 
				
			||||||
{ASN1_R_BN_LIB                           ,"bn lib"},
 | 
					{ERR_REASON(ASN1_R_BN_LIB)               ,"bn lib"},
 | 
				
			||||||
{ASN1_R_BOOLEAN_IS_WRONG_LENGTH          ,"boolean is wrong length"},
 | 
					{ERR_REASON(ASN1_R_BOOLEAN_IS_WRONG_LENGTH),"boolean is wrong length"},
 | 
				
			||||||
{ASN1_R_BUFFER_TOO_SMALL                 ,"buffer too small"},
 | 
					{ERR_REASON(ASN1_R_BUFFER_TOO_SMALL)     ,"buffer too small"},
 | 
				
			||||||
{ASN1_R_CIPHER_HAS_NO_OBJECT_IDENTIFIER  ,"cipher has no object identifier"},
 | 
					{ERR_REASON(ASN1_R_CIPHER_HAS_NO_OBJECT_IDENTIFIER),"cipher has no object identifier"},
 | 
				
			||||||
{ASN1_R_DATA_IS_WRONG                    ,"data is wrong"},
 | 
					{ERR_REASON(ASN1_R_DATA_IS_WRONG)        ,"data is wrong"},
 | 
				
			||||||
{ASN1_R_DECODE_ERROR                     ,"decode error"},
 | 
					{ERR_REASON(ASN1_R_DECODE_ERROR)         ,"decode error"},
 | 
				
			||||||
{ASN1_R_DECODING_ERROR                   ,"decoding error"},
 | 
					{ERR_REASON(ASN1_R_DECODING_ERROR)       ,"decoding error"},
 | 
				
			||||||
{ASN1_R_ENCODE_ERROR                     ,"encode error"},
 | 
					{ERR_REASON(ASN1_R_ENCODE_ERROR)         ,"encode error"},
 | 
				
			||||||
{ASN1_R_ERROR_GETTING_TIME               ,"error getting time"},
 | 
					{ERR_REASON(ASN1_R_ERROR_GETTING_TIME)   ,"error getting time"},
 | 
				
			||||||
{ASN1_R_ERROR_LOADING_SECTION            ,"error loading section"},
 | 
					{ERR_REASON(ASN1_R_ERROR_LOADING_SECTION),"error loading section"},
 | 
				
			||||||
{ASN1_R_ERROR_PARSING_SET_ELEMENT        ,"error parsing set element"},
 | 
					{ERR_REASON(ASN1_R_ERROR_PARSING_SET_ELEMENT),"error parsing set element"},
 | 
				
			||||||
{ASN1_R_ERROR_SETTING_CIPHER_PARAMS      ,"error setting cipher params"},
 | 
					{ERR_REASON(ASN1_R_ERROR_SETTING_CIPHER_PARAMS),"error setting cipher params"},
 | 
				
			||||||
{ASN1_R_EXPECTING_AN_INTEGER             ,"expecting an integer"},
 | 
					{ERR_REASON(ASN1_R_EXPECTING_AN_INTEGER) ,"expecting an integer"},
 | 
				
			||||||
{ASN1_R_EXPECTING_AN_OBJECT              ,"expecting an object"},
 | 
					{ERR_REASON(ASN1_R_EXPECTING_AN_OBJECT)  ,"expecting an object"},
 | 
				
			||||||
{ASN1_R_EXPECTING_A_BOOLEAN              ,"expecting a boolean"},
 | 
					{ERR_REASON(ASN1_R_EXPECTING_A_BOOLEAN)  ,"expecting a boolean"},
 | 
				
			||||||
{ASN1_R_EXPECTING_A_TIME                 ,"expecting a time"},
 | 
					{ERR_REASON(ASN1_R_EXPECTING_A_TIME)     ,"expecting a time"},
 | 
				
			||||||
{ASN1_R_EXPLICIT_LENGTH_MISMATCH         ,"explicit length mismatch"},
 | 
					{ERR_REASON(ASN1_R_EXPLICIT_LENGTH_MISMATCH),"explicit length mismatch"},
 | 
				
			||||||
{ASN1_R_EXPLICIT_TAG_NOT_CONSTRUCTED     ,"explicit tag not constructed"},
 | 
					{ERR_REASON(ASN1_R_EXPLICIT_TAG_NOT_CONSTRUCTED),"explicit tag not constructed"},
 | 
				
			||||||
{ASN1_R_FIELD_MISSING                    ,"field missing"},
 | 
					{ERR_REASON(ASN1_R_FIELD_MISSING)        ,"field missing"},
 | 
				
			||||||
{ASN1_R_FIRST_NUM_TOO_LARGE              ,"first num too large"},
 | 
					{ERR_REASON(ASN1_R_FIRST_NUM_TOO_LARGE)  ,"first num too large"},
 | 
				
			||||||
{ASN1_R_HEADER_TOO_LONG                  ,"header too long"},
 | 
					{ERR_REASON(ASN1_R_HEADER_TOO_LONG)      ,"header too long"},
 | 
				
			||||||
{ASN1_R_ILLEGAL_CHARACTERS               ,"illegal characters"},
 | 
					{ERR_REASON(ASN1_R_ILLEGAL_CHARACTERS)   ,"illegal characters"},
 | 
				
			||||||
{ASN1_R_ILLEGAL_NULL                     ,"illegal null"},
 | 
					{ERR_REASON(ASN1_R_ILLEGAL_NULL)         ,"illegal null"},
 | 
				
			||||||
{ASN1_R_ILLEGAL_OPTIONAL_ANY             ,"illegal optional any"},
 | 
					{ERR_REASON(ASN1_R_ILLEGAL_OPTIONAL_ANY) ,"illegal optional any"},
 | 
				
			||||||
{ASN1_R_ILLEGAL_OPTIONS_ON_ITEM_TEMPLATE ,"illegal options on item template"},
 | 
					{ERR_REASON(ASN1_R_ILLEGAL_OPTIONS_ON_ITEM_TEMPLATE),"illegal options on item template"},
 | 
				
			||||||
{ASN1_R_ILLEGAL_TAGGED_ANY               ,"illegal tagged any"},
 | 
					{ERR_REASON(ASN1_R_ILLEGAL_TAGGED_ANY)   ,"illegal tagged any"},
 | 
				
			||||||
{ASN1_R_INTEGER_TOO_LARGE_FOR_LONG       ,"integer too large for long"},
 | 
					{ERR_REASON(ASN1_R_INTEGER_TOO_LARGE_FOR_LONG),"integer too large for long"},
 | 
				
			||||||
{ASN1_R_INVALID_BMPSTRING_LENGTH         ,"invalid bmpstring length"},
 | 
					{ERR_REASON(ASN1_R_INVALID_BMPSTRING_LENGTH),"invalid bmpstring length"},
 | 
				
			||||||
{ASN1_R_INVALID_DIGIT                    ,"invalid digit"},
 | 
					{ERR_REASON(ASN1_R_INVALID_DIGIT)        ,"invalid digit"},
 | 
				
			||||||
{ASN1_R_INVALID_SEPARATOR                ,"invalid separator"},
 | 
					{ERR_REASON(ASN1_R_INVALID_SEPARATOR)    ,"invalid separator"},
 | 
				
			||||||
{ASN1_R_INVALID_TIME_FORMAT              ,"invalid time format"},
 | 
					{ERR_REASON(ASN1_R_INVALID_TIME_FORMAT)  ,"invalid time format"},
 | 
				
			||||||
{ASN1_R_INVALID_UNIVERSALSTRING_LENGTH   ,"invalid universalstring length"},
 | 
					{ERR_REASON(ASN1_R_INVALID_UNIVERSALSTRING_LENGTH),"invalid universalstring length"},
 | 
				
			||||||
{ASN1_R_INVALID_UTF8STRING               ,"invalid utf8string"},
 | 
					{ERR_REASON(ASN1_R_INVALID_UTF8STRING)   ,"invalid utf8string"},
 | 
				
			||||||
{ASN1_R_IV_TOO_LARGE                     ,"iv too large"},
 | 
					{ERR_REASON(ASN1_R_IV_TOO_LARGE)         ,"iv too large"},
 | 
				
			||||||
{ASN1_R_LENGTH_ERROR                     ,"length error"},
 | 
					{ERR_REASON(ASN1_R_LENGTH_ERROR)         ,"length error"},
 | 
				
			||||||
{ASN1_R_MISSING_EOC                      ,"missing eoc"},
 | 
					{ERR_REASON(ASN1_R_MISSING_EOC)          ,"missing eoc"},
 | 
				
			||||||
{ASN1_R_MISSING_SECOND_NUMBER            ,"missing second number"},
 | 
					{ERR_REASON(ASN1_R_MISSING_SECOND_NUMBER),"missing second number"},
 | 
				
			||||||
{ASN1_R_MSTRING_NOT_UNIVERSAL            ,"mstring not universal"},
 | 
					{ERR_REASON(ASN1_R_MSTRING_NOT_UNIVERSAL),"mstring not universal"},
 | 
				
			||||||
{ASN1_R_MSTRING_WRONG_TAG                ,"mstring wrong tag"},
 | 
					{ERR_REASON(ASN1_R_MSTRING_WRONG_TAG)    ,"mstring wrong tag"},
 | 
				
			||||||
{ASN1_R_NON_HEX_CHARACTERS               ,"non hex characters"},
 | 
					{ERR_REASON(ASN1_R_NESTED_ASN1_STRING)   ,"nested asn1 string"},
 | 
				
			||||||
{ASN1_R_NOT_ENOUGH_DATA                  ,"not enough data"},
 | 
					{ERR_REASON(ASN1_R_NON_HEX_CHARACTERS)   ,"non hex characters"},
 | 
				
			||||||
{ASN1_R_NO_MATCHING_CHOICE_TYPE          ,"no matching choice type"},
 | 
					{ERR_REASON(ASN1_R_NOT_ENOUGH_DATA)      ,"not enough data"},
 | 
				
			||||||
{ASN1_R_NULL_IS_WRONG_LENGTH             ,"null is wrong length"},
 | 
					{ERR_REASON(ASN1_R_NO_MATCHING_CHOICE_TYPE),"no matching choice type"},
 | 
				
			||||||
{ASN1_R_ODD_NUMBER_OF_CHARS              ,"odd number of chars"},
 | 
					{ERR_REASON(ASN1_R_NULL_IS_WRONG_LENGTH) ,"null is wrong length"},
 | 
				
			||||||
{ASN1_R_PRIVATE_KEY_HEADER_MISSING       ,"private key header missing"},
 | 
					{ERR_REASON(ASN1_R_ODD_NUMBER_OF_CHARS)  ,"odd number of chars"},
 | 
				
			||||||
{ASN1_R_SECOND_NUMBER_TOO_LARGE          ,"second number too large"},
 | 
					{ERR_REASON(ASN1_R_PRIVATE_KEY_HEADER_MISSING),"private key header missing"},
 | 
				
			||||||
{ASN1_R_SEQUENCE_LENGTH_MISMATCH         ,"sequence length mismatch"},
 | 
					{ERR_REASON(ASN1_R_SECOND_NUMBER_TOO_LARGE),"second number too large"},
 | 
				
			||||||
{ASN1_R_SEQUENCE_NOT_CONSTRUCTED         ,"sequence not constructed"},
 | 
					{ERR_REASON(ASN1_R_SEQUENCE_LENGTH_MISMATCH),"sequence length mismatch"},
 | 
				
			||||||
{ASN1_R_SHORT_LINE                       ,"short line"},
 | 
					{ERR_REASON(ASN1_R_SEQUENCE_NOT_CONSTRUCTED),"sequence not constructed"},
 | 
				
			||||||
{ASN1_R_STRING_TOO_LONG                  ,"string too long"},
 | 
					{ERR_REASON(ASN1_R_SHORT_LINE)           ,"short line"},
 | 
				
			||||||
{ASN1_R_STRING_TOO_SHORT                 ,"string too short"},
 | 
					{ERR_REASON(ASN1_R_STRING_TOO_LONG)      ,"string too long"},
 | 
				
			||||||
{ASN1_R_TAG_VALUE_TOO_HIGH               ,"tag value too high"},
 | 
					{ERR_REASON(ASN1_R_STRING_TOO_SHORT)     ,"string too short"},
 | 
				
			||||||
{ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD,"the asn1 object identifier is not known for this md"},
 | 
					{ERR_REASON(ASN1_R_TAG_VALUE_TOO_HIGH)   ,"tag value too high"},
 | 
				
			||||||
{ASN1_R_TOO_LONG                         ,"too long"},
 | 
					{ERR_REASON(ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD),"the asn1 object identifier is not known for this md"},
 | 
				
			||||||
{ASN1_R_TYPE_NOT_CONSTRUCTED             ,"type not constructed"},
 | 
					{ERR_REASON(ASN1_R_TOO_LONG)             ,"too long"},
 | 
				
			||||||
{ASN1_R_UNABLE_TO_DECODE_RSA_KEY         ,"unable to decode rsa key"},
 | 
					{ERR_REASON(ASN1_R_TYPE_NOT_CONSTRUCTED) ,"type not constructed"},
 | 
				
			||||||
{ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY ,"unable to decode rsa private key"},
 | 
					{ERR_REASON(ASN1_R_UNABLE_TO_DECODE_RSA_KEY),"unable to decode rsa key"},
 | 
				
			||||||
{ASN1_R_UNEXPECTED_EOC                   ,"unexpected eoc"},
 | 
					{ERR_REASON(ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY),"unable to decode rsa private key"},
 | 
				
			||||||
{ASN1_R_UNKNOWN_FORMAT                   ,"unknown format"},
 | 
					{ERR_REASON(ASN1_R_UNEXPECTED_EOC)       ,"unexpected eoc"},
 | 
				
			||||||
{ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM ,"unknown message digest algorithm"},
 | 
					{ERR_REASON(ASN1_R_UNKNOWN_FORMAT)       ,"unknown format"},
 | 
				
			||||||
{ASN1_R_UNKNOWN_OBJECT_TYPE              ,"unknown object type"},
 | 
					{ERR_REASON(ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM),"unknown message digest algorithm"},
 | 
				
			||||||
{ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE          ,"unknown public key type"},
 | 
					{ERR_REASON(ASN1_R_UNKNOWN_OBJECT_TYPE)  ,"unknown object type"},
 | 
				
			||||||
{ASN1_R_UNSUPPORTED_ANY_DEFINED_BY_TYPE  ,"unsupported any defined by type"},
 | 
					{ERR_REASON(ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE),"unknown public key type"},
 | 
				
			||||||
{ASN1_R_UNSUPPORTED_CIPHER               ,"unsupported cipher"},
 | 
					{ERR_REASON(ASN1_R_UNSUPPORTED_ANY_DEFINED_BY_TYPE),"unsupported any defined by type"},
 | 
				
			||||||
{ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM ,"unsupported encryption algorithm"},
 | 
					{ERR_REASON(ASN1_R_UNSUPPORTED_CIPHER)   ,"unsupported cipher"},
 | 
				
			||||||
{ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE      ,"unsupported public key type"},
 | 
					{ERR_REASON(ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM),"unsupported encryption algorithm"},
 | 
				
			||||||
{ASN1_R_WRONG_TAG                        ,"wrong tag"},
 | 
					{ERR_REASON(ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE),"unsupported public key type"},
 | 
				
			||||||
{ASN1_R_WRONG_TYPE                       ,"wrong type"},
 | 
					{ERR_REASON(ASN1_R_WRONG_TAG)            ,"wrong tag"},
 | 
				
			||||||
 | 
					{ERR_REASON(ASN1_R_WRONG_TYPE)           ,"wrong type"},
 | 
				
			||||||
{0,NULL}
 | 
					{0,NULL}
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -234,8 +246,8 @@ void ERR_load_ASN1_strings(void)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		init=0;
 | 
							init=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ERR
 | 
					#ifndef OPENSSL_NO_ERR
 | 
				
			||||||
		ERR_load_strings(ERR_LIB_ASN1,ASN1_str_functs);
 | 
							ERR_load_strings(0,ASN1_str_functs);
 | 
				
			||||||
		ERR_load_strings(ERR_LIB_ASN1,ASN1_str_reasons);
 | 
							ERR_load_strings(0,ASN1_str_reasons);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -349,6 +349,7 @@ int ASN1_STRING_set(ASN1_STRING *str, const void *_data, int len)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		if (str->data == NULL)
 | 
							if (str->data == NULL)
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_ASN1_STRING_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
			str->data=c;
 | 
								str->data=c;
 | 
				
			||||||
			return(0);
 | 
								return(0);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -115,7 +115,11 @@ int ASN1_TYPE_set_int_octetstring(ASN1_TYPE *a, long num, unsigned char *data,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	if ((osp=ASN1_STRING_new()) == NULL) return(0);
 | 
						if ((osp=ASN1_STRING_new()) == NULL) return(0);
 | 
				
			||||||
	/* Grow the 'string' */
 | 
						/* Grow the 'string' */
 | 
				
			||||||
	ASN1_STRING_set(osp,NULL,size);
 | 
						if (!ASN1_STRING_set(osp,NULL,size))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ASN1_STRING_free(osp);
 | 
				
			||||||
 | 
							return(0);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	M_ASN1_STRING_length_set(osp, size);
 | 
						M_ASN1_STRING_length_set(osp, size);
 | 
				
			||||||
	p=M_ASN1_STRING_data(osp);
 | 
						p=M_ASN1_STRING_data(osp);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -76,47 +76,55 @@ IMPLEMENT_ASN1_FUNCTIONS(PBEPARAM)
 | 
				
			|||||||
X509_ALGOR *PKCS5_pbe_set(int alg, int iter, unsigned char *salt,
 | 
					X509_ALGOR *PKCS5_pbe_set(int alg, int iter, unsigned char *salt,
 | 
				
			||||||
	     int saltlen)
 | 
						     int saltlen)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	PBEPARAM *pbe;
 | 
						PBEPARAM *pbe=NULL;
 | 
				
			||||||
	ASN1_OBJECT *al;
 | 
						ASN1_OBJECT *al;
 | 
				
			||||||
	X509_ALGOR *algor;
 | 
						X509_ALGOR *algor;
 | 
				
			||||||
	ASN1_TYPE *astype;
 | 
						ASN1_TYPE *astype=NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!(pbe = PBEPARAM_new ())) {
 | 
						if (!(pbe = PBEPARAM_new ())) {
 | 
				
			||||||
		ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
							ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
		return NULL;
 | 
							goto err;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if(iter <= 0) iter = PKCS5_DEFAULT_ITER;
 | 
						if(iter <= 0) iter = PKCS5_DEFAULT_ITER;
 | 
				
			||||||
	ASN1_INTEGER_set (pbe->iter, iter);
 | 
						if (!ASN1_INTEGER_set(pbe->iter, iter)) {
 | 
				
			||||||
 | 
							ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
							goto err;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	if (!saltlen) saltlen = PKCS5_SALT_LEN;
 | 
						if (!saltlen) saltlen = PKCS5_SALT_LEN;
 | 
				
			||||||
	if (!(pbe->salt->data = OPENSSL_malloc (saltlen))) {
 | 
						if (!(pbe->salt->data = OPENSSL_malloc (saltlen))) {
 | 
				
			||||||
		ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
							ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
		return NULL;
 | 
							goto err;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	pbe->salt->length = saltlen;
 | 
						pbe->salt->length = saltlen;
 | 
				
			||||||
	if (salt) memcpy (pbe->salt->data, salt, saltlen);
 | 
						if (salt) memcpy (pbe->salt->data, salt, saltlen);
 | 
				
			||||||
	else if (RAND_pseudo_bytes (pbe->salt->data, saltlen) < 0)
 | 
						else if (RAND_pseudo_bytes (pbe->salt->data, saltlen) < 0)
 | 
				
			||||||
		return NULL;
 | 
							goto err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!(astype = ASN1_TYPE_new())) {
 | 
						if (!(astype = ASN1_TYPE_new())) {
 | 
				
			||||||
		ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
							ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
		return NULL;
 | 
							goto err;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	astype->type = V_ASN1_SEQUENCE;
 | 
						astype->type = V_ASN1_SEQUENCE;
 | 
				
			||||||
	if(!ASN1_pack_string(pbe, i2d_PBEPARAM, &astype->value.sequence)) {
 | 
						if(!ASN1_pack_string(pbe, i2d_PBEPARAM, &astype->value.sequence)) {
 | 
				
			||||||
		ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
							ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
		return NULL;
 | 
							goto err;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	PBEPARAM_free (pbe);
 | 
						PBEPARAM_free (pbe);
 | 
				
			||||||
 | 
						pbe = NULL;
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	al = OBJ_nid2obj(alg); /* never need to free al */
 | 
						al = OBJ_nid2obj(alg); /* never need to free al */
 | 
				
			||||||
	if (!(algor = X509_ALGOR_new())) {
 | 
						if (!(algor = X509_ALGOR_new())) {
 | 
				
			||||||
		ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
							ASN1err(ASN1_F_ASN1_PBE_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
		return NULL;
 | 
							goto err;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	ASN1_OBJECT_free(algor->algorithm);
 | 
						ASN1_OBJECT_free(algor->algorithm);
 | 
				
			||||||
	algor->algorithm = al;
 | 
						algor->algorithm = al;
 | 
				
			||||||
	algor->parameter = astype;
 | 
						algor->parameter = astype;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return (algor);
 | 
						return (algor);
 | 
				
			||||||
 | 
					err:
 | 
				
			||||||
 | 
						if (pbe != NULL) PBEPARAM_free(pbe);
 | 
				
			||||||
 | 
						if (astype != NULL) ASN1_TYPE_free(astype);
 | 
				
			||||||
 | 
						return NULL;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -84,7 +84,10 @@ int ASN1_BIT_STRING_set_asc(ASN1_BIT_STRING *bs, char *name, int value,
 | 
				
			|||||||
	int bitnum;
 | 
						int bitnum;
 | 
				
			||||||
	bitnum = ASN1_BIT_STRING_num_asc(name, tbl);
 | 
						bitnum = ASN1_BIT_STRING_num_asc(name, tbl);
 | 
				
			||||||
	if(bitnum < 0) return 0;
 | 
						if(bitnum < 0) return 0;
 | 
				
			||||||
	if(bs) ASN1_BIT_STRING_set_bit(bs, bitnum, value);
 | 
						if(bs) {
 | 
				
			||||||
 | 
							if(!ASN1_BIT_STRING_set_bit(bs, bitnum, value))
 | 
				
			||||||
 | 
								return 0;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -66,6 +66,7 @@
 | 
				
			|||||||
#include <openssl/err.h>
 | 
					#include <openssl/err.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int asn1_check_eoc(unsigned char **in, long len);
 | 
					static int asn1_check_eoc(unsigned char **in, long len);
 | 
				
			||||||
 | 
					static int asn1_find_end(unsigned char **in, long len, char inf);
 | 
				
			||||||
static int asn1_collect(BUF_MEM *buf, unsigned char **in, long len, char inf, int tag, int aclass);
 | 
					static int asn1_collect(BUF_MEM *buf, unsigned char **in, long len, char inf, int tag, int aclass);
 | 
				
			||||||
static int collect_data(BUF_MEM *buf, unsigned char **p, long plen);
 | 
					static int collect_data(BUF_MEM *buf, unsigned char **p, long plen);
 | 
				
			||||||
static int asn1_check_tlen(long *olen, int *otag, unsigned char *oclass, char *inf, char *cst,
 | 
					static int asn1_check_tlen(long *olen, int *otag, unsigned char *oclass, char *inf, char *cst,
 | 
				
			||||||
@@ -644,7 +645,7 @@ static int asn1_d2i_ex_primitive(ASN1_VALUE **pval, unsigned char **in, long inl
 | 
				
			|||||||
		cont = *in;
 | 
							cont = *in;
 | 
				
			||||||
		/* If indefinite length constructed find the real end */
 | 
							/* If indefinite length constructed find the real end */
 | 
				
			||||||
		if(inf) {
 | 
							if(inf) {
 | 
				
			||||||
			if(!asn1_collect(NULL, &p, plen, inf, -1, -1)) goto err;
 | 
								if(!asn1_find_end(&p, plen, inf)) goto err;
 | 
				
			||||||
			len = p - cont;
 | 
								len = p - cont;
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			len = p - cont + plen;
 | 
								len = p - cont + plen;
 | 
				
			||||||
@@ -807,12 +808,66 @@ int asn1_ex_c2i(ASN1_VALUE **pval, unsigned char *cont, int len, int utype, char
 | 
				
			|||||||
	return ret;
 | 
						return ret;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* This function finds the end of an ASN1 structure when passed its maximum
 | 
				
			||||||
 | 
					 * length, whether it is indefinite length and a pointer to the content.
 | 
				
			||||||
 | 
					 * This is more efficient than calling asn1_collect because it does not
 | 
				
			||||||
 | 
					 * recurse on each indefinite length header.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int asn1_find_end(unsigned char **in, long len, char inf)
 | 
				
			||||||
 | 
						{
 | 
				
			||||||
 | 
						int expected_eoc;
 | 
				
			||||||
 | 
						long plen;
 | 
				
			||||||
 | 
						unsigned char *p = *in, *q;
 | 
				
			||||||
 | 
						/* If not indefinite length constructed just add length */
 | 
				
			||||||
 | 
						if (inf == 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							*in += len;
 | 
				
			||||||
 | 
							return 1;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						expected_eoc = 1;
 | 
				
			||||||
 | 
						/* Indefinite length constructed form. Find the end when enough EOCs
 | 
				
			||||||
 | 
						 * are found. If more indefinite length constructed headers
 | 
				
			||||||
 | 
						 * are encountered increment the expected eoc count otherwise justi
 | 
				
			||||||
 | 
						 * skip to the end of the data.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						while (len > 0)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							if(asn1_check_eoc(&p, len))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								expected_eoc--;
 | 
				
			||||||
 | 
								if (expected_eoc == 0)
 | 
				
			||||||
 | 
									break;
 | 
				
			||||||
 | 
								len -= 2;
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							q = p;
 | 
				
			||||||
 | 
							/* Just read in a header: only care about the length */
 | 
				
			||||||
 | 
							if(!asn1_check_tlen(&plen, NULL, NULL, &inf, NULL, &p, len,
 | 
				
			||||||
 | 
									-1, 0, 0, NULL))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_ASN1_FIND_END, ERR_R_NESTED_ASN1_ERROR);
 | 
				
			||||||
 | 
								return 0;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							if (inf)
 | 
				
			||||||
 | 
								expected_eoc++;
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								p += plen;
 | 
				
			||||||
 | 
							len -= p - q;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						if (expected_eoc)
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							ASN1err(ASN1_F_ASN1_FIND_END, ASN1_R_MISSING_EOC);
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						*in = p;
 | 
				
			||||||
 | 
						return 1;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* This function collects the asn1 data from a constructred string
 | 
					/* This function collects the asn1 data from a constructred string
 | 
				
			||||||
 * type into a buffer. The values of 'in' and 'len' should refer
 | 
					 * type into a buffer. The values of 'in' and 'len' should refer
 | 
				
			||||||
 * to the contents of the constructed type and 'inf' should be set
 | 
					 * to the contents of the constructed type and 'inf' should be set
 | 
				
			||||||
 * if it is indefinite length. If 'buf' is NULL then we just want
 | 
					 * if it is indefinite length.
 | 
				
			||||||
 * to find the end of the current structure: useful for indefinite
 | 
					 | 
				
			||||||
 * length constructed stuff.
 | 
					 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int asn1_collect(BUF_MEM *buf, unsigned char **in, long len, char inf, int tag, int aclass)
 | 
					static int asn1_collect(BUF_MEM *buf, unsigned char **in, long len, char inf, int tag, int aclass)
 | 
				
			||||||
@@ -822,11 +877,6 @@ static int asn1_collect(BUF_MEM *buf, unsigned char **in, long len, char inf, in
 | 
				
			|||||||
	char cst, ininf;
 | 
						char cst, ininf;
 | 
				
			||||||
	p = *in;
 | 
						p = *in;
 | 
				
			||||||
	inf &= 1;
 | 
						inf &= 1;
 | 
				
			||||||
	/* If no buffer and not indefinite length constructed just pass over the encoded data */
 | 
					 | 
				
			||||||
	if(!buf && !inf) {
 | 
					 | 
				
			||||||
		*in += len;
 | 
					 | 
				
			||||||
		return 1;
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	while(len > 0) {
 | 
						while(len > 0) {
 | 
				
			||||||
		q = p;
 | 
							q = p;
 | 
				
			||||||
		/* Check for EOC */
 | 
							/* Check for EOC */
 | 
				
			||||||
@@ -845,7 +895,13 @@ static int asn1_collect(BUF_MEM *buf, unsigned char **in, long len, char inf, in
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		/* If indefinite length constructed update max length */
 | 
							/* If indefinite length constructed update max length */
 | 
				
			||||||
		if(cst) {
 | 
							if(cst) {
 | 
				
			||||||
			if(!asn1_collect(buf, &p, plen, ininf, tag, aclass)) return 0;
 | 
					#ifdef OPENSSL_ALLOW_NESTED_ASN1_STRINGS
 | 
				
			||||||
 | 
								if (!asn1_collect(buf, &p, plen, ininf, tag, aclass))
 | 
				
			||||||
 | 
									return 0;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
								ASN1err(ASN1_F_ASN1_COLLECT, ASN1_R_NESTED_ASN1_STRING);
 | 
				
			||||||
 | 
								return 0;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
		} else {
 | 
							} else {
 | 
				
			||||||
			if(!collect_data(buf, &p, plen)) return 0;
 | 
								if(!collect_data(buf, &p, plen)) return 0;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -130,6 +130,7 @@ int X509_CRL_add0_revoked(X509_CRL *crl, X509_REVOKED *rev)
 | 
				
			|||||||
		ASN1err(ASN1_F_X509_CRL_ADD0_REVOKED, ERR_R_MALLOC_FAILURE);
 | 
							ASN1err(ASN1_F_X509_CRL_ADD0_REVOKED, ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
		return 0;
 | 
							return 0;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						inf->enc.modified = 1;
 | 
				
			||||||
	return 1;
 | 
						return 1;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -160,21 +160,22 @@ static int x509_name_ex_d2i(ASN1_VALUE **val, unsigned char **in, long len, cons
 | 
				
			|||||||
					int tag, int aclass, char opt, ASN1_TLC *ctx)
 | 
										int tag, int aclass, char opt, ASN1_TLC *ctx)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	unsigned char *p = *in, *q;
 | 
						unsigned char *p = *in, *q;
 | 
				
			||||||
	STACK *intname = NULL;
 | 
						STACK *intname = NULL, **intname_pp = &intname;
 | 
				
			||||||
	int i, j, ret;
 | 
						int i, j, ret;
 | 
				
			||||||
	X509_NAME *nm = NULL;
 | 
						X509_NAME *nm = NULL, **nm_pp = &nm;
 | 
				
			||||||
	STACK_OF(X509_NAME_ENTRY) *entries;
 | 
						STACK_OF(X509_NAME_ENTRY) *entries;
 | 
				
			||||||
	X509_NAME_ENTRY *entry;
 | 
						X509_NAME_ENTRY *entry;
 | 
				
			||||||
	q = p;
 | 
						q = p;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	/* Get internal representation of Name */
 | 
						/* Get internal representation of Name */
 | 
				
			||||||
	ret = ASN1_item_ex_d2i((ASN1_VALUE **)&intname, &p, len, ASN1_ITEM_rptr(X509_NAME_INTERNAL),
 | 
						ret = ASN1_item_ex_d2i((ASN1_VALUE **)intname_pp,
 | 
				
			||||||
								tag, aclass, opt, ctx);
 | 
								       &p, len, ASN1_ITEM_rptr(X509_NAME_INTERNAL),
 | 
				
			||||||
 | 
								       tag, aclass, opt, ctx);
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
	if(ret <= 0) return ret;
 | 
						if(ret <= 0) return ret;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if(*val) x509_name_ex_free(val, NULL);
 | 
						if(*val) x509_name_ex_free(val, NULL);
 | 
				
			||||||
	if(!x509_name_ex_new((ASN1_VALUE **)&nm, NULL)) goto err;
 | 
						if(!x509_name_ex_new((ASN1_VALUE **)nm_pp, NULL)) goto err;
 | 
				
			||||||
	/* We've decoded it: now cache encoding */
 | 
						/* We've decoded it: now cache encoding */
 | 
				
			||||||
	if(!BUF_MEM_grow(nm->bytes, p - q)) goto err;
 | 
						if(!BUF_MEM_grow(nm->bytes, p - q)) goto err;
 | 
				
			||||||
	memcpy(nm->bytes->data, q, p - q);
 | 
						memcpy(nm->bytes->data, q, p - q);
 | 
				
			||||||
@@ -218,7 +219,7 @@ static int x509_name_ex_i2d(ASN1_VALUE **val, unsigned char **out, const ASN1_IT
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static int x509_name_encode(X509_NAME *a)
 | 
					static int x509_name_encode(X509_NAME *a)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	STACK *intname = NULL;
 | 
						STACK *intname = NULL, **intname_pp = &intname;
 | 
				
			||||||
	int len;
 | 
						int len;
 | 
				
			||||||
	unsigned char *p;
 | 
						unsigned char *p;
 | 
				
			||||||
	STACK_OF(X509_NAME_ENTRY) *entries = NULL;
 | 
						STACK_OF(X509_NAME_ENTRY) *entries = NULL;
 | 
				
			||||||
@@ -236,10 +237,12 @@ static int x509_name_encode(X509_NAME *a)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		if(!sk_X509_NAME_ENTRY_push(entries, entry)) goto memerr;
 | 
							if(!sk_X509_NAME_ENTRY_push(entries, entry)) goto memerr;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	len = ASN1_item_ex_i2d((ASN1_VALUE **)&intname, NULL, ASN1_ITEM_rptr(X509_NAME_INTERNAL), -1, -1);
 | 
						len = ASN1_item_ex_i2d((ASN1_VALUE **)intname_pp, NULL,
 | 
				
			||||||
 | 
								       ASN1_ITEM_rptr(X509_NAME_INTERNAL), -1, -1);
 | 
				
			||||||
	if (!BUF_MEM_grow(a->bytes,len)) goto memerr;
 | 
						if (!BUF_MEM_grow(a->bytes,len)) goto memerr;
 | 
				
			||||||
	p=(unsigned char *)a->bytes->data;
 | 
						p=(unsigned char *)a->bytes->data;
 | 
				
			||||||
	ASN1_item_ex_i2d((ASN1_VALUE **)&intname, &p, ASN1_ITEM_rptr(X509_NAME_INTERNAL), -1, -1);
 | 
						ASN1_item_ex_i2d((ASN1_VALUE **)intname_pp,
 | 
				
			||||||
 | 
								 &p, ASN1_ITEM_rptr(X509_NAME_INTERNAL), -1, -1);
 | 
				
			||||||
	sk_pop_free(intname, sk_internal_free);
 | 
						sk_pop_free(intname, sk_internal_free);
 | 
				
			||||||
	a->modified = 0;
 | 
						a->modified = 0;
 | 
				
			||||||
	return len;
 | 
						return len;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -80,8 +80,7 @@ IMPLEMENT_ASN1_FUNCTIONS(X509_PUBKEY)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey)
 | 
					int X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int ok=0;
 | 
						X509_PUBKEY *pk=NULL;
 | 
				
			||||||
	X509_PUBKEY *pk;
 | 
					 | 
				
			||||||
	X509_ALGOR *a;
 | 
						X509_ALGOR *a;
 | 
				
			||||||
	ASN1_OBJECT *o;
 | 
						ASN1_OBJECT *o;
 | 
				
			||||||
	unsigned char *s,*p = NULL;
 | 
						unsigned char *s,*p = NULL;
 | 
				
			||||||
@@ -104,7 +103,11 @@ int X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey)
 | 
				
			|||||||
			(a->parameter->type != V_ASN1_NULL))
 | 
								(a->parameter->type != V_ASN1_NULL))
 | 
				
			||||||
			{
 | 
								{
 | 
				
			||||||
			ASN1_TYPE_free(a->parameter);
 | 
								ASN1_TYPE_free(a->parameter);
 | 
				
			||||||
			a->parameter=ASN1_TYPE_new();
 | 
								if (!(a->parameter=ASN1_TYPE_new()))
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
									X509err(X509_F_X509_PUBKEY_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
									goto err;
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
			a->parameter->type=V_ASN1_NULL;
 | 
								a->parameter->type=V_ASN1_NULL;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -118,14 +121,34 @@ int X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey)
 | 
				
			|||||||
		dsa=pkey->pkey.dsa;
 | 
							dsa=pkey->pkey.dsa;
 | 
				
			||||||
		dsa->write_params=0;
 | 
							dsa->write_params=0;
 | 
				
			||||||
		ASN1_TYPE_free(a->parameter);
 | 
							ASN1_TYPE_free(a->parameter);
 | 
				
			||||||
		i=i2d_DSAparams(dsa,NULL);
 | 
							if ((i=i2d_DSAparams(dsa,NULL)) <= 0)
 | 
				
			||||||
		if ((p=(unsigned char *)OPENSSL_malloc(i)) == NULL) goto err;
 | 
								goto err;
 | 
				
			||||||
 | 
							if (!(p=(unsigned char *)OPENSSL_malloc(i)))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								X509err(X509_F_X509_PUBKEY_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								goto err;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		pp=p;
 | 
							pp=p;
 | 
				
			||||||
		i2d_DSAparams(dsa,&pp);
 | 
							i2d_DSAparams(dsa,&pp);
 | 
				
			||||||
		a->parameter=ASN1_TYPE_new();
 | 
							if (!(a->parameter=ASN1_TYPE_new()))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								OPENSSL_free(p);
 | 
				
			||||||
 | 
								X509err(X509_F_X509_PUBKEY_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								goto err;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		a->parameter->type=V_ASN1_SEQUENCE;
 | 
							a->parameter->type=V_ASN1_SEQUENCE;
 | 
				
			||||||
		a->parameter->value.sequence=ASN1_STRING_new();
 | 
							if (!(a->parameter->value.sequence=ASN1_STRING_new()))
 | 
				
			||||||
		ASN1_STRING_set(a->parameter->value.sequence,p,i);
 | 
								{
 | 
				
			||||||
 | 
								OPENSSL_free(p);
 | 
				
			||||||
 | 
								X509err(X509_F_X509_PUBKEY_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								goto err;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							if (!ASN1_STRING_set(a->parameter->value.sequence,p,i))
 | 
				
			||||||
 | 
								{
 | 
				
			||||||
 | 
								OPENSSL_free(p);
 | 
				
			||||||
 | 
								X509err(X509_F_X509_PUBKEY_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
								goto err;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		OPENSSL_free(p);
 | 
							OPENSSL_free(p);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
@@ -143,7 +166,11 @@ int X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey)
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	p=s;
 | 
						p=s;
 | 
				
			||||||
	i2d_PublicKey(pkey,&p);
 | 
						i2d_PublicKey(pkey,&p);
 | 
				
			||||||
	if (!M_ASN1_BIT_STRING_set(pk->public_key,s,i)) goto err;
 | 
						if (!M_ASN1_BIT_STRING_set(pk->public_key,s,i))
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
							X509err(X509_F_X509_PUBKEY_SET,ERR_R_MALLOC_FAILURE);
 | 
				
			||||||
 | 
							goto err;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	/* Set number of unused bits to zero */
 | 
						/* Set number of unused bits to zero */
 | 
				
			||||||
	pk->public_key->flags&= ~(ASN1_STRING_FLAG_BITS_LEFT|0x07);
 | 
						pk->public_key->flags&= ~(ASN1_STRING_FLAG_BITS_LEFT|0x07);
 | 
				
			||||||
	pk->public_key->flags|=ASN1_STRING_FLAG_BITS_LEFT;
 | 
						pk->public_key->flags|=ASN1_STRING_FLAG_BITS_LEFT;
 | 
				
			||||||
@@ -159,12 +186,11 @@ int X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey)
 | 
				
			|||||||
		X509_PUBKEY_free(*x);
 | 
							X509_PUBKEY_free(*x);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	*x=pk;
 | 
						*x=pk;
 | 
				
			||||||
	pk=NULL;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ok=1;
 | 
						return 1;
 | 
				
			||||||
err:
 | 
					err:
 | 
				
			||||||
	if (pk != NULL) X509_PUBKEY_free(pk);
 | 
						if (pk != NULL) X509_PUBKEY_free(pk);
 | 
				
			||||||
	return(ok);
 | 
						return 0;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
EVP_PKEY *X509_PUBKEY_get(X509_PUBKEY *key)
 | 
					EVP_PKEY *X509_PUBKEY_get(X509_PUBKEY *key)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
lib
 | 
					lib
 | 
				
			||||||
Makefile.save
 | 
					Makefile.save
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -74,7 +74,7 @@ links:
 | 
				
			|||||||
install: installs
 | 
					install: installs
 | 
				
			||||||
 | 
					
 | 
				
			||||||
installs:
 | 
					installs:
 | 
				
			||||||
	@for i in $(EXHEADER) ; \
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist ; \
 | 
				
			||||||
	do  \
 | 
						do  \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
@@ -109,5 +109,8 @@ bf_enc.o: ../../include/openssl/blowfish.h ../../include/openssl/e_os2.h
 | 
				
			|||||||
bf_enc.o: ../../include/openssl/opensslconf.h bf_enc.c bf_locl.h
 | 
					bf_enc.o: ../../include/openssl/opensslconf.h bf_enc.c bf_locl.h
 | 
				
			||||||
bf_ofb64.o: ../../include/openssl/blowfish.h ../../include/openssl/e_os2.h
 | 
					bf_ofb64.o: ../../include/openssl/blowfish.h ../../include/openssl/e_os2.h
 | 
				
			||||||
bf_ofb64.o: ../../include/openssl/opensslconf.h bf_locl.h bf_ofb64.c
 | 
					bf_ofb64.o: ../../include/openssl/opensslconf.h bf_locl.h bf_ofb64.c
 | 
				
			||||||
bf_skey.o: ../../include/openssl/blowfish.h ../../include/openssl/e_os2.h
 | 
					bf_skey.o: ../../include/openssl/blowfish.h ../../include/openssl/crypto.h
 | 
				
			||||||
bf_skey.o: ../../include/openssl/opensslconf.h bf_locl.h bf_pi.h bf_skey.c
 | 
					bf_skey.o: ../../include/openssl/e_os2.h ../../include/openssl/fips.h
 | 
				
			||||||
 | 
					bf_skey.o: ../../include/openssl/opensslconf.h ../../include/openssl/opensslv.h
 | 
				
			||||||
 | 
					bf_skey.o: ../../include/openssl/safestack.h ../../include/openssl/stack.h
 | 
				
			||||||
 | 
					bf_skey.o: ../../include/openssl/symhacks.h bf_locl.h bf_pi.h bf_skey.c
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
bx86unix.cpp
 | 
					bx86unix.cpp
 | 
				
			||||||
bx86-elf.s
 | 
					bx86-elf.s
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -58,11 +58,13 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include <stdio.h>
 | 
					#include <stdio.h>
 | 
				
			||||||
#include <string.h>
 | 
					#include <string.h>
 | 
				
			||||||
 | 
					#include <openssl/crypto.h>
 | 
				
			||||||
#include <openssl/blowfish.h>
 | 
					#include <openssl/blowfish.h>
 | 
				
			||||||
 | 
					#include <openssl/fips.h>
 | 
				
			||||||
#include "bf_locl.h"
 | 
					#include "bf_locl.h"
 | 
				
			||||||
#include "bf_pi.h"
 | 
					#include "bf_pi.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void BF_set_key(BF_KEY *key, int len, const unsigned char *data)
 | 
					FIPS_NON_FIPS_VCIPHER_Init(BF)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
	BF_LONG *p,ri,in[2];
 | 
						BF_LONG *p,ri,in[2];
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -105,6 +105,9 @@ typedef struct bf_key_st
 | 
				
			|||||||
	} BF_KEY;
 | 
						} BF_KEY;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef OPENSSL_FIPS 
 | 
				
			||||||
 | 
					void private_BF_set_key(BF_KEY *key, int len, const unsigned char *data);
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
void BF_set_key(BF_KEY *key, int len, const unsigned char *data);
 | 
					void BF_set_key(BF_KEY *key, int len, const unsigned char *data);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void BF_encrypt(BF_LONG *data,const BF_KEY *key);
 | 
					void BF_encrypt(BF_LONG *data,const BF_KEY *key);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
lib
 | 
					lib
 | 
				
			||||||
Makefile.save
 | 
					Makefile.save
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -61,7 +61,7 @@ links:
 | 
				
			|||||||
	@$(PERL) $(TOP)/util/mklink.pl ../../apps $(APPS)
 | 
						@$(PERL) $(TOP)/util/mklink.pl ../../apps $(APPS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install:
 | 
					install:
 | 
				
			||||||
	@for i in $(EXHEADER); \
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist; \
 | 
				
			||||||
	do  \
 | 
						do  \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -576,7 +576,7 @@ abs_val(LDOUBLE value)
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static LDOUBLE
 | 
					static LDOUBLE
 | 
				
			||||||
pow10(int in_exp)
 | 
					pow_10(int in_exp)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    LDOUBLE result = 1;
 | 
					    LDOUBLE result = 1;
 | 
				
			||||||
    while (in_exp) {
 | 
					    while (in_exp) {
 | 
				
			||||||
@@ -639,11 +639,11 @@ fmtfp(
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    /* we "cheat" by converting the fractional part to integer by
 | 
					    /* we "cheat" by converting the fractional part to integer by
 | 
				
			||||||
       multiplying by a factor of 10 */
 | 
					       multiplying by a factor of 10 */
 | 
				
			||||||
    fracpart = roundv((pow10(max)) * (ufvalue - intpart));
 | 
					    fracpart = roundv((pow_10(max)) * (ufvalue - intpart));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (fracpart >= (long)pow10(max)) {
 | 
					    if (fracpart >= (long)pow_10(max)) {
 | 
				
			||||||
        intpart++;
 | 
					        intpart++;
 | 
				
			||||||
        fracpart -= (long)pow10(max);
 | 
					        fracpart -= (long)pow_10(max);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* convert integer part */
 | 
					    /* convert integer part */
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,6 @@
 | 
				
			|||||||
/* crypto/bio/bio_err.c */
 | 
					/* crypto/bio/bio_err.c */
 | 
				
			||||||
/* ====================================================================
 | 
					/* ====================================================================
 | 
				
			||||||
 * Copyright (c) 1999 The OpenSSL Project.  All rights reserved.
 | 
					 * Copyright (c) 1999-2005 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
 | 
				
			||||||
@@ -64,73 +64,77 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
/* BEGIN ERROR CODES */
 | 
					/* BEGIN ERROR CODES */
 | 
				
			||||||
#ifndef OPENSSL_NO_ERR
 | 
					#ifndef OPENSSL_NO_ERR
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define ERR_FUNC(func) ERR_PACK(ERR_LIB_BIO,func,0)
 | 
				
			||||||
 | 
					#define ERR_REASON(reason) ERR_PACK(ERR_LIB_BIO,0,reason)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static ERR_STRING_DATA BIO_str_functs[]=
 | 
					static ERR_STRING_DATA BIO_str_functs[]=
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
{ERR_PACK(0,BIO_F_ACPT_STATE,0),	"ACPT_STATE"},
 | 
					{ERR_FUNC(BIO_F_ACPT_STATE),	"ACPT_STATE"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_ACCEPT,0),	"BIO_accept"},
 | 
					{ERR_FUNC(BIO_F_BIO_ACCEPT),	"BIO_accept"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_BER_GET_HEADER,0),	"BIO_BER_GET_HEADER"},
 | 
					{ERR_FUNC(BIO_F_BIO_BER_GET_HEADER),	"BIO_BER_GET_HEADER"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_CTRL,0),	"BIO_ctrl"},
 | 
					{ERR_FUNC(BIO_F_BIO_CTRL),	"BIO_ctrl"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_GETHOSTBYNAME,0),	"BIO_gethostbyname"},
 | 
					{ERR_FUNC(BIO_F_BIO_GETHOSTBYNAME),	"BIO_gethostbyname"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_GETS,0),	"BIO_gets"},
 | 
					{ERR_FUNC(BIO_F_BIO_GETS),	"BIO_gets"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_GET_ACCEPT_SOCKET,0),	"BIO_get_accept_socket"},
 | 
					{ERR_FUNC(BIO_F_BIO_GET_ACCEPT_SOCKET),	"BIO_get_accept_socket"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_GET_HOST_IP,0),	"BIO_get_host_ip"},
 | 
					{ERR_FUNC(BIO_F_BIO_GET_HOST_IP),	"BIO_get_host_ip"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_GET_PORT,0),	"BIO_get_port"},
 | 
					{ERR_FUNC(BIO_F_BIO_GET_PORT),	"BIO_get_port"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_MAKE_PAIR,0),	"BIO_MAKE_PAIR"},
 | 
					{ERR_FUNC(BIO_F_BIO_MAKE_PAIR),	"BIO_MAKE_PAIR"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NEW,0),	"BIO_new"},
 | 
					{ERR_FUNC(BIO_F_BIO_NEW),	"BIO_new"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NEW_FILE,0),	"BIO_new_file"},
 | 
					{ERR_FUNC(BIO_F_BIO_NEW_FILE),	"BIO_new_file"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NEW_MEM_BUF,0),	"BIO_new_mem_buf"},
 | 
					{ERR_FUNC(BIO_F_BIO_NEW_MEM_BUF),	"BIO_new_mem_buf"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NREAD,0),	"BIO_nread"},
 | 
					{ERR_FUNC(BIO_F_BIO_NREAD),	"BIO_nread"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NREAD0,0),	"BIO_nread0"},
 | 
					{ERR_FUNC(BIO_F_BIO_NREAD0),	"BIO_nread0"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NWRITE,0),	"BIO_nwrite"},
 | 
					{ERR_FUNC(BIO_F_BIO_NWRITE),	"BIO_nwrite"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_NWRITE0,0),	"BIO_nwrite0"},
 | 
					{ERR_FUNC(BIO_F_BIO_NWRITE0),	"BIO_nwrite0"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_PUTS,0),	"BIO_puts"},
 | 
					{ERR_FUNC(BIO_F_BIO_PUTS),	"BIO_puts"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_READ,0),	"BIO_read"},
 | 
					{ERR_FUNC(BIO_F_BIO_READ),	"BIO_read"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_SOCK_INIT,0),	"BIO_sock_init"},
 | 
					{ERR_FUNC(BIO_F_BIO_SOCK_INIT),	"BIO_sock_init"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BIO_WRITE,0),	"BIO_write"},
 | 
					{ERR_FUNC(BIO_F_BIO_WRITE),	"BIO_write"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_BUFFER_CTRL,0),	"BUFFER_CTRL"},
 | 
					{ERR_FUNC(BIO_F_BUFFER_CTRL),	"BUFFER_CTRL"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_CONN_CTRL,0),	"CONN_CTRL"},
 | 
					{ERR_FUNC(BIO_F_CONN_CTRL),	"CONN_CTRL"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_CONN_STATE,0),	"CONN_STATE"},
 | 
					{ERR_FUNC(BIO_F_CONN_STATE),	"CONN_STATE"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_FILE_CTRL,0),	"FILE_CTRL"},
 | 
					{ERR_FUNC(BIO_F_FILE_CTRL),	"FILE_CTRL"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_FILE_READ,0),	"FILE_READ"},
 | 
					{ERR_FUNC(BIO_F_FILE_READ),	"FILE_READ"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_LINEBUFFER_CTRL,0),	"LINEBUFFER_CTRL"},
 | 
					{ERR_FUNC(BIO_F_LINEBUFFER_CTRL),	"LINEBUFFER_CTRL"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_MEM_READ,0),	"MEM_READ"},
 | 
					{ERR_FUNC(BIO_F_MEM_READ),	"MEM_READ"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_MEM_WRITE,0),	"MEM_WRITE"},
 | 
					{ERR_FUNC(BIO_F_MEM_WRITE),	"MEM_WRITE"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_SSL_NEW,0),	"SSL_new"},
 | 
					{ERR_FUNC(BIO_F_SSL_NEW),	"SSL_new"},
 | 
				
			||||||
{ERR_PACK(0,BIO_F_WSASTARTUP,0),	"WSASTARTUP"},
 | 
					{ERR_FUNC(BIO_F_WSASTARTUP),	"WSASTARTUP"},
 | 
				
			||||||
{0,NULL}
 | 
					{0,NULL}
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static ERR_STRING_DATA BIO_str_reasons[]=
 | 
					static ERR_STRING_DATA BIO_str_reasons[]=
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
{BIO_R_ACCEPT_ERROR                      ,"accept error"},
 | 
					{ERR_REASON(BIO_R_ACCEPT_ERROR)          ,"accept error"},
 | 
				
			||||||
{BIO_R_BAD_FOPEN_MODE                    ,"bad fopen mode"},
 | 
					{ERR_REASON(BIO_R_BAD_FOPEN_MODE)        ,"bad fopen mode"},
 | 
				
			||||||
{BIO_R_BAD_HOSTNAME_LOOKUP               ,"bad hostname lookup"},
 | 
					{ERR_REASON(BIO_R_BAD_HOSTNAME_LOOKUP)   ,"bad hostname lookup"},
 | 
				
			||||||
{BIO_R_BROKEN_PIPE                       ,"broken pipe"},
 | 
					{ERR_REASON(BIO_R_BROKEN_PIPE)           ,"broken pipe"},
 | 
				
			||||||
{BIO_R_CONNECT_ERROR                     ,"connect error"},
 | 
					{ERR_REASON(BIO_R_CONNECT_ERROR)         ,"connect error"},
 | 
				
			||||||
{BIO_R_EOF_ON_MEMORY_BIO                 ,"EOF on memory BIO"},
 | 
					{ERR_REASON(BIO_R_EOF_ON_MEMORY_BIO)     ,"EOF on memory BIO"},
 | 
				
			||||||
{BIO_R_ERROR_SETTING_NBIO                ,"error setting nbio"},
 | 
					{ERR_REASON(BIO_R_ERROR_SETTING_NBIO)    ,"error setting nbio"},
 | 
				
			||||||
{BIO_R_ERROR_SETTING_NBIO_ON_ACCEPTED_SOCKET,"error setting nbio on accepted socket"},
 | 
					{ERR_REASON(BIO_R_ERROR_SETTING_NBIO_ON_ACCEPTED_SOCKET),"error setting nbio on accepted socket"},
 | 
				
			||||||
{BIO_R_ERROR_SETTING_NBIO_ON_ACCEPT_SOCKET,"error setting nbio on accept socket"},
 | 
					{ERR_REASON(BIO_R_ERROR_SETTING_NBIO_ON_ACCEPT_SOCKET),"error setting nbio on accept socket"},
 | 
				
			||||||
{BIO_R_GETHOSTBYNAME_ADDR_IS_NOT_AF_INET ,"gethostbyname addr is not af inet"},
 | 
					{ERR_REASON(BIO_R_GETHOSTBYNAME_ADDR_IS_NOT_AF_INET),"gethostbyname addr is not af inet"},
 | 
				
			||||||
{BIO_R_INVALID_ARGUMENT                  ,"invalid argument"},
 | 
					{ERR_REASON(BIO_R_INVALID_ARGUMENT)      ,"invalid argument"},
 | 
				
			||||||
{BIO_R_INVALID_IP_ADDRESS                ,"invalid ip address"},
 | 
					{ERR_REASON(BIO_R_INVALID_IP_ADDRESS)    ,"invalid ip address"},
 | 
				
			||||||
{BIO_R_IN_USE                            ,"in use"},
 | 
					{ERR_REASON(BIO_R_IN_USE)                ,"in use"},
 | 
				
			||||||
{BIO_R_KEEPALIVE                         ,"keepalive"},
 | 
					{ERR_REASON(BIO_R_KEEPALIVE)             ,"keepalive"},
 | 
				
			||||||
{BIO_R_NBIO_CONNECT_ERROR                ,"nbio connect error"},
 | 
					{ERR_REASON(BIO_R_NBIO_CONNECT_ERROR)    ,"nbio connect error"},
 | 
				
			||||||
{BIO_R_NO_ACCEPT_PORT_SPECIFIED          ,"no accept port specified"},
 | 
					{ERR_REASON(BIO_R_NO_ACCEPT_PORT_SPECIFIED),"no accept port specified"},
 | 
				
			||||||
{BIO_R_NO_HOSTNAME_SPECIFIED             ,"no hostname specified"},
 | 
					{ERR_REASON(BIO_R_NO_HOSTNAME_SPECIFIED) ,"no hostname specified"},
 | 
				
			||||||
{BIO_R_NO_PORT_DEFINED                   ,"no port defined"},
 | 
					{ERR_REASON(BIO_R_NO_PORT_DEFINED)       ,"no port defined"},
 | 
				
			||||||
{BIO_R_NO_PORT_SPECIFIED                 ,"no port specified"},
 | 
					{ERR_REASON(BIO_R_NO_PORT_SPECIFIED)     ,"no port specified"},
 | 
				
			||||||
{BIO_R_NO_SUCH_FILE                      ,"no such file"},
 | 
					{ERR_REASON(BIO_R_NO_SUCH_FILE)          ,"no such file"},
 | 
				
			||||||
{BIO_R_NULL_PARAMETER                    ,"null parameter"},
 | 
					{ERR_REASON(BIO_R_NULL_PARAMETER)        ,"null parameter"},
 | 
				
			||||||
{BIO_R_TAG_MISMATCH                      ,"tag mismatch"},
 | 
					{ERR_REASON(BIO_R_TAG_MISMATCH)          ,"tag mismatch"},
 | 
				
			||||||
{BIO_R_UNABLE_TO_BIND_SOCKET             ,"unable to bind socket"},
 | 
					{ERR_REASON(BIO_R_UNABLE_TO_BIND_SOCKET) ,"unable to bind socket"},
 | 
				
			||||||
{BIO_R_UNABLE_TO_CREATE_SOCKET           ,"unable to create socket"},
 | 
					{ERR_REASON(BIO_R_UNABLE_TO_CREATE_SOCKET),"unable to create socket"},
 | 
				
			||||||
{BIO_R_UNABLE_TO_LISTEN_SOCKET           ,"unable to listen socket"},
 | 
					{ERR_REASON(BIO_R_UNABLE_TO_LISTEN_SOCKET),"unable to listen socket"},
 | 
				
			||||||
{BIO_R_UNINITIALIZED                     ,"uninitialized"},
 | 
					{ERR_REASON(BIO_R_UNINITIALIZED)         ,"uninitialized"},
 | 
				
			||||||
{BIO_R_UNSUPPORTED_METHOD                ,"unsupported method"},
 | 
					{ERR_REASON(BIO_R_UNSUPPORTED_METHOD)    ,"unsupported method"},
 | 
				
			||||||
{BIO_R_WRITE_TO_READ_ONLY_BIO            ,"write to read only BIO"},
 | 
					{ERR_REASON(BIO_R_WRITE_TO_READ_ONLY_BIO),"write to read only BIO"},
 | 
				
			||||||
{BIO_R_WSASTARTUP                        ,"WSAStartup"},
 | 
					{ERR_REASON(BIO_R_WSASTARTUP)            ,"WSAStartup"},
 | 
				
			||||||
{0,NULL}
 | 
					{0,NULL}
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -144,8 +148,8 @@ void ERR_load_BIO_strings(void)
 | 
				
			|||||||
		{
 | 
							{
 | 
				
			||||||
		init=0;
 | 
							init=0;
 | 
				
			||||||
#ifndef OPENSSL_NO_ERR
 | 
					#ifndef OPENSSL_NO_ERR
 | 
				
			||||||
		ERR_load_strings(ERR_LIB_BIO,BIO_str_functs);
 | 
							ERR_load_strings(0,BIO_str_functs);
 | 
				
			||||||
		ERR_load_strings(ERR_LIB_BIO,BIO_str_reasons);
 | 
							ERR_load_strings(0,BIO_str_reasons);
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -469,7 +469,7 @@ static long conn_ctrl(BIO *b, int cmd, long num, void *ptr)
 | 
				
			|||||||
		break;
 | 
							break;
 | 
				
			||||||
	case BIO_C_DO_STATE_MACHINE:
 | 
						case BIO_C_DO_STATE_MACHINE:
 | 
				
			||||||
		/* use this one to start the connection */
 | 
							/* use this one to start the connection */
 | 
				
			||||||
		if (!data->state != BIO_CONN_S_OK)
 | 
							if (!(data->state != BIO_CONN_S_OK))
 | 
				
			||||||
			ret=(long)conn_state(b,data);
 | 
								ret=(long)conn_state(b,data);
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
			ret=1;
 | 
								ret=1;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -266,7 +266,7 @@ static long MS_CALLBACK file_ctrl(BIO *b, int cmd, long num, void *ptr)
 | 
				
			|||||||
			ret=0;
 | 
								ret=0;
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
#if defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_OS2)
 | 
					#if defined(OPENSSL_SYS_MSDOS) || defined(OPENSSL_SYS_WINDOWS) || defined(OPENSSL_SYS_OS2) || defined(OPENSSL_SYS_WIN32_CYGWIN)
 | 
				
			||||||
		if (!(num & BIO_FP_TEXT))
 | 
							if (!(num & BIO_FP_TEXT))
 | 
				
			||||||
			strcat(p,"b");
 | 
								strcat(p,"b");
 | 
				
			||||||
		else
 | 
							else
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,2 +1,4 @@
 | 
				
			|||||||
lib
 | 
					lib
 | 
				
			||||||
Makefile.save
 | 
					Makefile.save
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -31,12 +31,12 @@ LIB=$(TOP)/libcrypto.a
 | 
				
			|||||||
LIBSRC=	bn_add.c bn_div.c bn_exp.c bn_lib.c bn_ctx.c bn_mul.c bn_mod.c \
 | 
					LIBSRC=	bn_add.c bn_div.c bn_exp.c bn_lib.c bn_ctx.c bn_mul.c bn_mod.c \
 | 
				
			||||||
	bn_print.c bn_rand.c bn_shift.c bn_word.c bn_blind.c \
 | 
						bn_print.c bn_rand.c bn_shift.c bn_word.c bn_blind.c \
 | 
				
			||||||
	bn_kron.c bn_sqrt.c bn_gcd.c bn_prime.c bn_err.c bn_sqr.c bn_asm.c \
 | 
						bn_kron.c bn_sqrt.c bn_gcd.c bn_prime.c bn_err.c bn_sqr.c bn_asm.c \
 | 
				
			||||||
	bn_recp.c bn_mont.c bn_mpi.c bn_exp2.c
 | 
						bn_recp.c bn_mont.c bn_mpi.c bn_exp2.c bn_x931p.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
LIBOBJ=	bn_add.o bn_div.o bn_exp.o bn_lib.o bn_ctx.o bn_mul.o bn_mod.o \
 | 
					LIBOBJ=	bn_add.o bn_div.o bn_exp.o bn_lib.o bn_ctx.o bn_mul.o bn_mod.o \
 | 
				
			||||||
	bn_print.o bn_rand.o bn_shift.o bn_word.o bn_blind.o \
 | 
						bn_print.o bn_rand.o bn_shift.o bn_word.o bn_blind.o \
 | 
				
			||||||
	bn_kron.o bn_sqrt.o bn_gcd.o bn_prime.o bn_err.o bn_sqr.o $(BN_ASM) \
 | 
						bn_kron.o bn_sqrt.o bn_gcd.o bn_prime.o bn_err.o bn_sqr.o $(BN_ASM) \
 | 
				
			||||||
	bn_recp.o bn_mont.o bn_mpi.o bn_exp2.o
 | 
						bn_recp.o bn_mont.o bn_mpi.o bn_exp2.o bn_x931p.o
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SRC= $(LIBSRC)
 | 
					SRC= $(LIBSRC)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -118,10 +118,17 @@ asm/ia64-cpp.o:	asm/ia64.S
 | 
				
			|||||||
	rm -f /tmp/ia64.$$$$.s
 | 
						rm -f /tmp/ia64.$$$$.s
 | 
				
			||||||
 | 
					
 | 
				
			||||||
asm/x86_64-gcc.o: asm/x86_64-gcc.c
 | 
					asm/x86_64-gcc.o: asm/x86_64-gcc.c
 | 
				
			||||||
 | 
						$(CC) $(ASFLAGS) -c -o $@ $<
 | 
				
			||||||
 | 
					
 | 
				
			||||||
asm/pa-risc2W.o: asm/pa-risc2W.s
 | 
					asm/pa-risc2W.o: asm/pa-risc2W.s
 | 
				
			||||||
	/usr/ccs/bin/as -o asm/pa-risc2W.o asm/pa-risc2W.s
 | 
						/usr/ccs/bin/as -o asm/pa-risc2W.o asm/pa-risc2W.s
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					asm/linux_ppc32.s: asm/ppc.pl;	$(PERL) $< $@
 | 
				
			||||||
 | 
					asm/linux_ppc64.s: asm/ppc.pl;	$(PERL) $< $@
 | 
				
			||||||
 | 
					asm/aix_ppc32.s: asm/ppc.pl;	$(PERL) asm/ppc.pl $@
 | 
				
			||||||
 | 
					asm/aix_ppc64.s: asm/ppc.pl;	$(PERL) asm/ppc.pl $@
 | 
				
			||||||
 | 
					asm/osx_ppc32.s: asm/ppc.pl;	$(PERL) $< $@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
files:
 | 
					files:
 | 
				
			||||||
	$(PERL) $(TOP)/util/files.pl Makefile >> $(TOP)/MINFO
 | 
						$(PERL) $(TOP)/util/files.pl Makefile >> $(TOP)/MINFO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -131,7 +138,7 @@ links:
 | 
				
			|||||||
	@$(PERL) $(TOP)/util/mklink.pl ../../apps $(APPS)
 | 
						@$(PERL) $(TOP)/util/mklink.pl ../../apps $(APPS)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install:
 | 
					install:
 | 
				
			||||||
	@for i in $(EXHEADER) ; \
 | 
						@headerlist="$(EXHEADER)"; for i in $$headerlist ; \
 | 
				
			||||||
	do  \
 | 
						do  \
 | 
				
			||||||
	(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
						(cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i; \
 | 
				
			||||||
	chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
						chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$i ); \
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,3 +2,5 @@ bn86unix.cpp
 | 
				
			|||||||
co86unix.cpp
 | 
					co86unix.cpp
 | 
				
			||||||
bn86-elf.s
 | 
					bn86-elf.s
 | 
				
			||||||
co86-elf.s
 | 
					co86-elf.s
 | 
				
			||||||
 | 
					*.flc
 | 
				
			||||||
 | 
					semantic.cache
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2081
									
								
								crypto/bn/asm/ppc.pl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2081
									
								
								crypto/bn/asm/ppc.pl
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -13,20 +13,42 @@
 | 
				
			|||||||
 * A. Well, that's because this code is basically a quick-n-dirty
 | 
					 * A. Well, that's because this code is basically a quick-n-dirty
 | 
				
			||||||
 *    proof-of-concept hack. As you can see it's implemented with
 | 
					 *    proof-of-concept hack. As you can see it's implemented with
 | 
				
			||||||
 *    inline assembler, which means that you're bound to GCC and that
 | 
					 *    inline assembler, which means that you're bound to GCC and that
 | 
				
			||||||
 *    there must be a room for fine-tuning.
 | 
					 *    there might be enough room for further improvement.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Q. Why inline assembler?
 | 
					 * Q. Why inline assembler?
 | 
				
			||||||
 * A. x86_64 features own ABI I'm not familiar with. Which is why
 | 
					 * A. x86_64 features own ABI which I'm not familiar with. This is
 | 
				
			||||||
 *    I decided to let the compiler take care of subroutine
 | 
					 *    why I decided to let the compiler take care of subroutine
 | 
				
			||||||
 *    prologue/epilogue as well as register allocation.
 | 
					 *    prologue/epilogue as well as register allocation. For reference.
 | 
				
			||||||
 | 
					 *    Win64 implements different ABI for AMD64, different from Linux.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Q. How much faster does it get?
 | 
					 * Q. How much faster does it get?
 | 
				
			||||||
 * A. Unfortunately people sitting on x86_64 hardware are prohibited
 | 
					 * A. 'apps/openssl speed rsa dsa' output with no-asm:
 | 
				
			||||||
 *    to disclose the performance numbers, so they (SuSE labs to be
 | 
					 *
 | 
				
			||||||
 *    specific) wouldn't tell me. However! Very similar coding technique
 | 
					 *	                  sign    verify    sign/s verify/s
 | 
				
			||||||
 *    (reaching out for 128-bit result from 64x64-bit multiplication)
 | 
					 *	rsa  512 bits   0.0006s   0.0001s   1683.8  18456.2
 | 
				
			||||||
 *    results in >3 times performance improvement on MIPS and I see no
 | 
					 *	rsa 1024 bits   0.0028s   0.0002s    356.0   6407.0
 | 
				
			||||||
 *    reason why gain on x86_64 would be so much different:-)
 | 
					 *	rsa 2048 bits   0.0172s   0.0005s     58.0   1957.8
 | 
				
			||||||
 | 
					 *	rsa 4096 bits   0.1155s   0.0018s      8.7    555.6
 | 
				
			||||||
 | 
					 *	                  sign    verify    sign/s verify/s
 | 
				
			||||||
 | 
					 *	dsa  512 bits   0.0005s   0.0006s   2100.8   1768.3
 | 
				
			||||||
 | 
					 *	dsa 1024 bits   0.0014s   0.0018s    692.3    559.2
 | 
				
			||||||
 | 
					 *	dsa 2048 bits   0.0049s   0.0061s    204.7    165.0
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *    'apps/openssl speed rsa dsa' output with this module:
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *	                  sign    verify    sign/s verify/s
 | 
				
			||||||
 | 
					 *	rsa  512 bits   0.0004s   0.0000s   2767.1  33297.9
 | 
				
			||||||
 | 
					 *	rsa 1024 bits   0.0012s   0.0001s    867.4  14674.7
 | 
				
			||||||
 | 
					 *	rsa 2048 bits   0.0061s   0.0002s    164.0   5270.0
 | 
				
			||||||
 | 
					 *	rsa 4096 bits   0.0384s   0.0006s     26.1   1650.8
 | 
				
			||||||
 | 
					 *	                  sign    verify    sign/s verify/s
 | 
				
			||||||
 | 
					 *	dsa  512 bits   0.0002s   0.0003s   4442.2   3786.3
 | 
				
			||||||
 | 
					 *	dsa 1024 bits   0.0005s   0.0007s   1835.1   1497.4
 | 
				
			||||||
 | 
					 *	dsa 2048 bits   0.0016s   0.0020s    620.4    504.6
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 *    For the reference. IA-32 assembler implementation performs
 | 
				
			||||||
 | 
					 *    very much like 64-bit code compiled with no-asm on the same
 | 
				
			||||||
 | 
					 *    machine.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define BN_ULONG unsigned long
 | 
					#define BN_ULONG unsigned long
 | 
				
			||||||
@@ -151,7 +173,7 @@ BN_ULONG bn_div_words(BN_ULONG h, BN_ULONG l, BN_ULONG d)
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
BN_ULONG bn_add_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
					BN_ULONG bn_add_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
				
			||||||
{ BN_ULONG ret,i;
 | 
					{ BN_ULONG ret=0,i=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (n <= 0) return 0;
 | 
						if (n <= 0) return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -164,7 +186,7 @@ BN_ULONG bn_add_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
				
			|||||||
	"	leaq	1(%2),%2	\n"
 | 
						"	leaq	1(%2),%2	\n"
 | 
				
			||||||
	"	loop	1b		\n"
 | 
						"	loop	1b		\n"
 | 
				
			||||||
	"	sbbq	%0,%0		\n"
 | 
						"	sbbq	%0,%0		\n"
 | 
				
			||||||
		: "+a"(ret),"+c"(n),"+r"(i)
 | 
							: "=&a"(ret),"+c"(n),"=&r"(i)
 | 
				
			||||||
		: "r"(rp),"r"(ap),"r"(bp)
 | 
							: "r"(rp),"r"(ap),"r"(bp)
 | 
				
			||||||
		: "cc"
 | 
							: "cc"
 | 
				
			||||||
	);
 | 
						);
 | 
				
			||||||
@@ -174,7 +196,7 @@ BN_ULONG bn_add_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#ifndef SIMICS
 | 
					#ifndef SIMICS
 | 
				
			||||||
BN_ULONG bn_sub_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
					BN_ULONG bn_sub_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
				
			||||||
{ BN_ULONG ret,i;
 | 
					{ BN_ULONG ret=0,i=0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (n <= 0) return 0;
 | 
						if (n <= 0) return 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -187,7 +209,7 @@ BN_ULONG bn_sub_words (BN_ULONG *rp, BN_ULONG *ap, BN_ULONG *bp,int n)
 | 
				
			|||||||
	"	leaq	1(%2),%2	\n"
 | 
						"	leaq	1(%2),%2	\n"
 | 
				
			||||||
	"	loop	1b		\n"
 | 
						"	loop	1b		\n"
 | 
				
			||||||
	"	sbbq	%0,%0		\n"
 | 
						"	sbbq	%0,%0		\n"
 | 
				
			||||||
		: "+a"(ret),"+c"(n),"+r"(i)
 | 
							: "=&a"(ret),"+c"(n),"=&r"(i)
 | 
				
			||||||
		: "r"(rp),"r"(ap),"r"(bp)
 | 
							: "r"(rp),"r"(ap),"r"(bp)
 | 
				
			||||||
		: "cc"
 | 
							: "cc"
 | 
				
			||||||
	);
 | 
						);
 | 
				
			||||||
@@ -318,7 +340,6 @@ BN_ULONG bn_sub_words(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b, int n)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void bn_mul_comba8(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b)
 | 
					void bn_mul_comba8(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BN_ULONG bl,bh;
 | 
					 | 
				
			||||||
	BN_ULONG t1,t2;
 | 
						BN_ULONG t1,t2;
 | 
				
			||||||
	BN_ULONG c1,c2,c3;
 | 
						BN_ULONG c1,c2,c3;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -423,7 +444,6 @@ void bn_mul_comba8(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void bn_mul_comba4(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b)
 | 
					void bn_mul_comba4(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BN_ULONG bl,bh;
 | 
					 | 
				
			||||||
	BN_ULONG t1,t2;
 | 
						BN_ULONG t1,t2;
 | 
				
			||||||
	BN_ULONG c1,c2,c3;
 | 
						BN_ULONG c1,c2,c3;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -464,7 +484,6 @@ void bn_mul_comba4(BN_ULONG *r, BN_ULONG *a, BN_ULONG *b)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void bn_sqr_comba8(BN_ULONG *r, BN_ULONG *a)
 | 
					void bn_sqr_comba8(BN_ULONG *r, BN_ULONG *a)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BN_ULONG bl,bh;
 | 
					 | 
				
			||||||
	BN_ULONG t1,t2;
 | 
						BN_ULONG t1,t2;
 | 
				
			||||||
	BN_ULONG c1,c2,c3;
 | 
						BN_ULONG c1,c2,c3;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -541,7 +560,6 @@ void bn_sqr_comba8(BN_ULONG *r, BN_ULONG *a)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
void bn_sqr_comba4(BN_ULONG *r, BN_ULONG *a)
 | 
					void bn_sqr_comba4(BN_ULONG *r, BN_ULONG *a)
 | 
				
			||||||
	{
 | 
						{
 | 
				
			||||||
	BN_ULONG bl,bh;
 | 
					 | 
				
			||||||
	BN_ULONG t1,t2;
 | 
						BN_ULONG t1,t2;
 | 
				
			||||||
	BN_ULONG c1,c2,c3;
 | 
						BN_ULONG c1,c2,c3;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user