[openssl-dev] [openssl.org #4485] big number tests and Math::BigInt changes
Craig A. Berry via RT
rt at openssl.org
Sat Mar 26 02:38:47 UTC 2016
Wow, that was fast. The patch looks good here: now all tests pass on systems with and without the Math::BigInt changes. Thanks!
> On Mar 25, 2016, at 6:05 PM, Richard Levitte via RT <rt at openssl.org> wrote:
>
> I've attached a tentative patch for test/recipes/bc.pl. Would you be willing to
> try it out?
>
> --
> Ticket here: http://rt.openssl.org/Ticket/Display.html?id=4485
> Please log in as guest with password guest if prompted
>
> diff --git a/test/recipes/bc.pl b/test/recipes/bc.pl
> index 29a4a8a..f7d4dc6 100644
> --- a/test/recipes/bc.pl
> +++ b/test/recipes/bc.pl
> @@ -46,7 +46,16 @@ sub __multiplier {
> if ($operator eq "*") {
> $operand1->bmul($operand2);
> } elsif ($operator eq "/") {
> + # Math::BigInt->bdiv() is documented to do floored division,
> + # i.e. 1 / -4 = -1, while bc and OpenSSL BN_div do truncated
> + # division, i.e. 1 / -4 = 0. We need to make the operation
> + # work like OpenSSL's BN_div to be able to verify.
> + my $neg = ($operand1->is_neg()
> + ? !$operand2->is_neg() : $operand2->is_neg());
> + $operand1->babs();
> + $operand2->babs();
> $operand1->bdiv($operand2);
> + if ($neg) { $operand1->bneg(); }
> } elsif ($operator eq "%") {
> # Here's a bit of a quirk...
> # With OpenSSL's BN, as well as bc, the result of -10 % 3 is -1
________________________________________
Craig A. Berry
mailto:craigberry at mac.com
"... getting out of a sonnet is much more
difficult than getting in."
Brad Leithauser
--
Ticket here: http://rt.openssl.org/Ticket/Display.html?id=4485
Please log in as guest with password guest if prompted
More information about the openssl-dev
mailing list