From d7dc9a7ce3642f2cc6904f9ed406685029a2e825 Mon Sep 17 00:00:00 2001 From: Andy Polyakov Date: Thu, 2 Aug 2007 20:42:33 +0000 Subject: [PATCH] Platform check in FIPS_mode_set. --- fips-1.0/fips.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/fips-1.0/fips.c b/fips-1.0/fips.c index 372aa59377..cf6489672f 100644 --- a/fips-1.0/fips.c +++ b/fips-1.0/fips.c @@ -255,6 +255,16 @@ int FIPS_mode_set(int onoff) goto end; } +#ifdef OPENSSL_IA32_SSE2 + if ((OPENSSL_ia32cap & (1<<25|1<<26)) != (1<<25|1<<26)) + { + FIPSerr(FIPS_F_FIPS_MODE_SET,FIPS_R_UNSUPPORTED_PLATFORM); + fips_selftest_fail = 1; + ret = 0; + goto end; + } +#endif + if(fips_signature_witness() != FIPS_signature) { FIPSerr(FIPS_F_FIPS_MODE_SET,FIPS_R_CONTRADICTING_EVIDENCE); -- 2.25.1