37 lines
1.6 KiB
Plaintext
37 lines
1.6 KiB
Plaintext
=pod
|
|
|
|
=head1 NAME
|
|
|
|
OPENSSL_ia32cap - finding the IA-32 processor capabilities
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
unsigned long *OPENSSL_ia32cap_loc(void);
|
|
#define OPENSSL_ia32cap (*(OPENSSL_ia32cap_loc()))
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
Value returned by OPENSSL_ia32cap_loc() is address of a variable
|
|
containing IA-32 processor capabilities bit vector as it appears in EDX
|
|
register after executing CPUID instruction with EAX=1 input value (see
|
|
Intel Application Note #241618). Naturally it's meaningful on IA-32[E]
|
|
platforms only. The variable is normally set up automatically upon
|
|
toolkit initialization, but can be manipulated afterwards to modify
|
|
crypto library behaviour. For the moment of this writing five bits are
|
|
significant, namely bit #28 denoting Hyperthreading, which is used to
|
|
distinguish Intel P4 core, bit #26 denoting SSE2 support, bit #25
|
|
denoting SSE support, bit #23 denoting MMX support, and bit #4 denoting
|
|
presence of Time-Stamp Counter. Clearing bit #26 at run-time for
|
|
example disables high-performance SSE2 code present in the crypto
|
|
library. You might have to do this if target OpenSSL application is
|
|
executed on SSE2 capable CPU, but under control of OS which does not
|
|
support SSE2 extentions. Even though you can manipulate the value
|
|
programmatically, you most likely will find it more appropriate to set
|
|
up an environment variable with the same name prior starting target
|
|
application, e.g. 'env OPENSSL_ia32cap=0x12800010 apps/openssl', to
|
|
achieve same effect without modifying the application source code.
|
|
Alternatively you can reconfigure the toolkit with no-sse2 option and
|
|
recompile.
|
|
|
|
=cut
|