提交 70b76d39 编写于 作者: A Andy Polyakov

ppccap.c: fix compiler warning and perform sanity check outside signal masking.

ppc64-mont.pl: clarify comment and fix spelling.
上级 6a9d28f9
...@@ -56,10 +56,10 @@ ...@@ -56,10 +56,10 @@
# that asynchronous signals have to be blocked upon entry to this # that asynchronous signals have to be blocked upon entry to this
# subroutine. Signal masking (and complementary unmasking) has quite # subroutine. Signal masking (and complementary unmasking) has quite
# an impact on performance, naturally larger for shorter keys. It's # an impact on performance, naturally larger for shorter keys. It's
# so severe that shorter key performance can be as low as 1/3 of # so severe that 512-bit key performance can be as low as 1/3 of
# expected one. This is why this routine can be engaged for longer # expected one. This is why this routine can be engaged for longer
# key operations only, see crypto/ppccap.c for further details. # key operations only, see crypto/ppccap.c for further details.
# Alternative is to break dependance on upper halves on GPRs... # Alternative is to break dependence on upper halves on GPRs...
# MacOS X is an exception from this and doesn't require signal # MacOS X is an exception from this and doesn't require signal
# masking, and that's where above improvement coefficients were # masking, and that's where above improvement coefficients were
# collected. # collected.
......
...@@ -25,7 +25,7 @@ int bn_mul_mont(BN_ULONG *rp, const BN_ULONG *ap, const BN_ULONG *bp, const BN_U ...@@ -25,7 +25,7 @@ int bn_mul_mont(BN_ULONG *rp, const BN_ULONG *ap, const BN_ULONG *bp, const BN_U
#else #else
/* boundary of 32 was experimentally determined on /* boundary of 32 was experimentally determined on
Linux 2.6.22, might have to be adjusted on AIX... */ Linux 2.6.22, might have to be adjusted on AIX... */
if ((num>=32) && (OPENSSL_ppccap_P&PPC_FPU64)) if (num>=32 && (num&3)==0 && (OPENSSL_ppccap_P&PPC_FPU64))
{ {
sigset_t oset; sigset_t oset;
int ret; int ret;
...@@ -50,6 +50,8 @@ int bn_mul_mont(BN_ULONG *rp, const BN_ULONG *ap, const BN_ULONG *bp, const BN_U ...@@ -50,6 +50,8 @@ int bn_mul_mont(BN_ULONG *rp, const BN_ULONG *ap, const BN_ULONG *bp, const BN_U
static sigjmp_buf ill_jmp; static sigjmp_buf ill_jmp;
static void ill_handler (int sig) { siglongjmp(ill_jmp,sig); } static void ill_handler (int sig) { siglongjmp(ill_jmp,sig); }
void OPENSSL_ppc64_probe(void);
void OPENSSL_cpuid_setup(void) void OPENSSL_cpuid_setup(void)
{ {
char *e; char *e;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册