blob: bee36de25be95ffedd663e597b844d0f856614a2 [file] [log] [blame]
/*
* Copyright (C) 2012 Michael Brown <mbrown@fensystems.co.uk>.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301, USA.
*
* You can also choose to distribute this program under the terms of
* the Unmodified Binary Distribution Licence (as given in the file
* COPYING.UBDL), provided that you have satisfied its requirements.
*/
FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
/** @file
*
* Big integer self-tests
*
*/
/* Forcibly enable assertions */
#undef NDEBUG
#include <assert.h>
#include <string.h>
#include <ipxe/bigint.h>
#include <ipxe/test.h>
/** Define inline big integer */
#define BIGINT(...) { __VA_ARGS__ }
/* Provide global functions to allow inspection of generated assembly code */
void bigint_init_sample ( bigint_element_t *value0, unsigned int size,
const void *data, size_t len ) {
bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( void * ) value0 );
bigint_init ( value, data, len );
}
void bigint_done_sample ( const bigint_element_t *value0, unsigned int size,
void *out, size_t len ) {
const bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( const void * ) value0 );
bigint_done ( value, out, len );
}
int bigint_add_sample ( const bigint_element_t *addend0,
bigint_element_t *value0, unsigned int size ) {
const bigint_t ( size ) *addend __attribute__ (( may_alias ))
= ( ( const void * ) addend0 );
bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( void * ) value0 );
return bigint_add ( addend, value );
}
int bigint_subtract_sample ( const bigint_element_t *subtrahend0,
bigint_element_t *value0, unsigned int size ) {
const bigint_t ( size ) *subtrahend __attribute__ (( may_alias ))
= ( ( const void * ) subtrahend0 );
bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( void * ) value0 );
return bigint_subtract ( subtrahend, value );
}
void bigint_shl_sample ( bigint_element_t *value0, unsigned int size ) {
bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( void * ) value0 );
bigint_shl ( value );
}
void bigint_shr_sample ( bigint_element_t *value0, unsigned int size ) {
bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( void * ) value0 );
bigint_shr ( value );
}
int bigint_is_zero_sample ( const bigint_element_t *value0,
unsigned int size ) {
const bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( const void * ) value0 );
return bigint_is_zero ( value );
}
int bigint_is_geq_sample ( const bigint_element_t *value0,
const bigint_element_t *reference0,
unsigned int size ) {
const bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( const void * ) value0 );
const bigint_t ( size ) *reference __attribute__ (( may_alias ))
= ( ( const void * ) reference0 );
return bigint_is_geq ( value, reference );
}
int bigint_bit_is_set_sample ( const bigint_element_t *value0,
unsigned int size, unsigned int bit ) {
const bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( const void * ) value0 );
return bigint_bit_is_set ( value, bit );
}
int bigint_max_set_bit_sample ( const bigint_element_t *value0,
unsigned int size ) {
const bigint_t ( size ) *value __attribute__ (( may_alias ))
= ( ( const void * ) value0 );
return bigint_max_set_bit ( value );
}
void bigint_grow_sample ( const bigint_element_t *source0,
unsigned int source_size, bigint_element_t *dest0,
unsigned int dest_size ) {
const bigint_t ( source_size ) *source __attribute__ (( may_alias ))
= ( ( const void * ) source0 );
bigint_t ( dest_size ) *dest __attribute__ (( may_alias ))
= ( ( void * ) dest0 );
bigint_grow ( source, dest );
}
void bigint_shrink_sample ( const bigint_element_t *source0,
unsigned int source_size, bigint_element_t *dest0,
unsigned int dest_size ) {
const bigint_t ( source_size ) *source __attribute__ (( may_alias ))
= ( ( const void * ) source0 );
bigint_t ( dest_size ) *dest __attribute__ (( may_alias ))
= ( ( void * ) dest0 );
bigint_shrink ( source, dest );
}
void bigint_copy_sample ( const bigint_element_t *source0,
bigint_element_t *dest0, unsigned int size ) {
const bigint_t ( size ) *source __attribute__ (( may_alias ))
= ( ( const void * ) source0 );
bigint_t ( size ) *dest __attribute__ (( may_alias ))
= ( ( void * ) dest0 );
bigint_copy ( source, dest );
}
void bigint_swap_sample ( bigint_element_t *first0, bigint_element_t *second0,
unsigned int size, int swap ) {
bigint_t ( size ) *first __attribute__ (( may_alias ))
= ( ( void * ) first0 );
bigint_t ( size ) *second __attribute__ (( may_alias ))
= ( ( void * ) second0 );
bigint_swap ( first, second, swap );
}
void bigint_multiply_sample ( const bigint_element_t *multiplicand0,
unsigned int multiplicand_size,
const bigint_element_t *multiplier0,
unsigned int multiplier_size,
bigint_element_t *result0 ) {
unsigned int result_size = ( multiplicand_size + multiplier_size );
const bigint_t ( multiplicand_size ) __attribute__ (( may_alias ))
*multiplicand = ( ( const void * ) multiplicand0 );
const bigint_t ( multiplier_size ) __attribute__ (( may_alias ))
*multiplier = ( ( const void * ) multiplier0 );
bigint_t ( result_size ) __attribute__ (( may_alias ))
*result = ( ( void * ) result0 );
bigint_multiply ( multiplicand, multiplier, result );
}
void bigint_reduce_sample ( bigint_element_t *modulus0,
bigint_element_t *value0, unsigned int size ) {
bigint_t ( size ) __attribute__ (( may_alias ))
*modulus = ( ( void * ) modulus0 );
bigint_t ( size ) __attribute__ (( may_alias ))
*value = ( ( void * ) value0 );
bigint_reduce ( modulus, value );
}
void bigint_mod_invert_sample ( const bigint_element_t *invertend0,
bigint_element_t *inverse0,
unsigned int size ) {
const bigint_t ( size ) __attribute__ (( may_alias ))
*invertend = ( ( const void * ) invertend0 );
bigint_t ( size ) __attribute__ (( may_alias ))
*inverse = ( ( void * ) inverse0 );
bigint_mod_invert ( invertend, inverse );
}
void bigint_mod_multiply_sample ( const bigint_element_t *multiplicand0,
const bigint_element_t *multiplier0,
const bigint_element_t *modulus0,
bigint_element_t *result0,
unsigned int size,
void *tmp ) {
const bigint_t ( size ) *multiplicand __attribute__ (( may_alias ))
= ( ( const void * ) multiplicand0 );
const bigint_t ( size ) *multiplier __attribute__ (( may_alias ))
= ( ( const void * ) multiplier0 );
const bigint_t ( size ) *modulus __attribute__ (( may_alias ))
= ( ( const void * ) modulus0 );
bigint_t ( size ) *result __attribute__ (( may_alias ))
= ( ( void * ) result0 );
bigint_mod_multiply ( multiplicand, multiplier, modulus, result, tmp );
}
void bigint_mod_exp_sample ( const bigint_element_t *base0,
const bigint_element_t *modulus0,
const bigint_element_t *exponent0,
bigint_element_t *result0,
unsigned int size, unsigned int exponent_size,
void *tmp ) {
const bigint_t ( size ) *base __attribute__ (( may_alias ))
= ( ( const void * ) base0 );
const bigint_t ( size ) *modulus __attribute__ (( may_alias ))
= ( ( const void * ) modulus0 );
const bigint_t ( exponent_size ) *exponent __attribute__ (( may_alias ))
= ( ( const void * ) exponent0 );
bigint_t ( size ) *result __attribute__ (( may_alias ))
= ( ( void * ) result0 );
bigint_mod_exp ( base, modulus, exponent, result, tmp );
}
/**
* Report result of big integer addition test
*
* @v addend Big integer to add
* @v value Big integer to be added to
* @v expected Big integer expected result
* @v overflow Expected result overflows range
*/
#define bigint_add_ok( addend, value, expected, overflow ) do { \
static const uint8_t addend_raw[] = addend; \
static const uint8_t value_raw[] = value; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
unsigned int msb = ( 8 * sizeof ( value_raw ) ); \
bigint_t ( size ) addend_temp; \
bigint_t ( size ) value_temp; \
int carry; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &addend_temp ) == \
bigint_size ( &value_temp ) ); \
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
bigint_init ( &addend_temp, addend_raw, \
sizeof ( addend_raw ) ); \
DBG ( "Add:\n" ); \
DBG_HDA ( 0, &addend_temp, sizeof ( addend_temp ) ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
carry = bigint_add ( &addend_temp, &value_temp ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_done ( &value_temp, result_raw, sizeof ( result_raw ) ); \
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
if ( sizeof ( result_raw ) < sizeof ( value_temp ) ) \
carry += bigint_bit_is_set ( &value_temp, msb ); \
ok ( carry == overflow ); \
} while ( 0 )
/**
* Report result of big integer subtraction test
*
* @v subtrahend Big integer to subtract
* @v value Big integer to be subtracted from
* @v expected Big integer expected result
* @v underflow Expected result underflows range
*/
#define bigint_subtract_ok( subtrahend, value, expected, \
underflow ) do { \
static const uint8_t subtrahend_raw[] = subtrahend; \
static const uint8_t value_raw[] = value; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) subtrahend_temp; \
bigint_t ( size ) value_temp; \
int borrow; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &subtrahend_temp ) == \
bigint_size ( &value_temp ) ); \
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
bigint_init ( &subtrahend_temp, subtrahend_raw, \
sizeof ( subtrahend_raw ) ); \
DBG ( "Subtract:\n" ); \
DBG_HDA ( 0, &subtrahend_temp, sizeof ( subtrahend_temp ) ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
borrow = bigint_subtract ( &subtrahend_temp, &value_temp ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_done ( &value_temp, result_raw, sizeof ( result_raw ) ); \
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
ok ( borrow == underflow ); \
} while ( 0 )
/**
* Report result of big integer left shift test
*
* @v value Big integer
* @v expected Big integer expected result
*/
#define bigint_shl_ok( value, expected ) do { \
static const uint8_t value_raw[] = value; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) value_temp; \
{} /* Fix emacs alignment */ \
\
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
DBG ( "Shift left:\n" ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_shl ( &value_temp ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_done ( &value_temp, result_raw, sizeof ( result_raw ) ); \
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer right shift test
*
* @v value Big integer
* @v expected Big integer expected result
*/
#define bigint_shr_ok( value, expected ) do { \
static const uint8_t value_raw[] = value; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) value_temp; \
{} /* Fix emacs alignment */ \
\
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
DBG ( "Shift right:\n" ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_shr ( &value_temp ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_done ( &value_temp, result_raw, sizeof ( result_raw ) ); \
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer zero comparison test
*
* @v value Big integer
* @v expected Expected result
*/
#define bigint_is_zero_ok( value, expected ) do { \
static const uint8_t value_raw[] = value; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) value_temp; \
int is_zero; \
{} /* Fix emacs alignment */ \
\
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
DBG ( "Zero comparison:\n" ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
is_zero = bigint_is_zero ( &value_temp ); \
DBG ( "...is %szero\n", ( is_zero ? "" : "not " ) ); \
ok ( ( !! is_zero ) == ( !! (expected) ) ); \
} while ( 0 )
/**
* Report result of big integer greater-than-or-equal comparison test
*
* @v value Big integer
* @v reference Reference big integer
* @v expected Expected result
*/
#define bigint_is_geq_ok( value, reference, expected ) do { \
static const uint8_t value_raw[] = value; \
static const uint8_t reference_raw[] = reference; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) value_temp; \
bigint_t ( size ) reference_temp; \
int is_geq; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &reference_temp ) == \
bigint_size ( &value_temp ) ); \
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
bigint_init ( &reference_temp, reference_raw, \
sizeof ( reference_raw ) ); \
DBG ( "Greater-than-or-equal comparison:\n" ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
DBG_HDA ( 0, &reference_temp, sizeof ( reference_temp ) ); \
is_geq = bigint_is_geq ( &value_temp, &reference_temp ); \
DBG ( "...is %sgreater than or equal\n", \
( is_geq ? "" : "not " ) ); \
ok ( ( !! is_geq ) == ( !! (expected) ) ); \
} while ( 0 )
/**
* Report result of big integer bit-set test
*
* @v value Big integer
* @v bit Bit to test
* @v expected Expected result
*/
#define bigint_bit_is_set_ok( value, bit, expected ) do { \
static const uint8_t value_raw[] = value; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) value_temp; \
int bit_is_set; \
{} /* Fix emacs alignment */ \
\
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
DBG ( "Bit set:\n" ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bit_is_set = bigint_bit_is_set ( &value_temp, bit ); \
DBG ( "...bit %d is %sset\n", bit, \
( bit_is_set ? "" : "not " ) ); \
ok ( ( !! bit_is_set ) == ( !! (expected) ) ); \
} while ( 0 )
/**
* Report result of big integer maximum set bit test
*
* @v value Big integer
* @v expected Expected result
*/
#define bigint_max_set_bit_ok( value, expected ) do { \
static const uint8_t value_raw[] = value; \
unsigned int size = \
bigint_required_size ( sizeof ( value_raw ) ); \
bigint_t ( size ) value_temp; \
int max_set_bit; \
{} /* Fix emacs alignment */ \
\
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
DBG ( "Maximum set bit:\n" ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
max_set_bit = bigint_max_set_bit ( &value_temp ); \
DBG ( "...maximum set bit is bit %d\n", ( max_set_bit - 1 ) ); \
ok ( max_set_bit == (expected) ); \
} while ( 0 )
/**
* Report result of big integer swap test
*
* @v first Big integer to be conditionally swapped
* @v second Big integer to be conditionally swapped
*/
#define bigint_swap_ok( first, second ) do { \
static const uint8_t first_raw[] = first; \
static const uint8_t second_raw[] = second; \
uint8_t temp[ sizeof ( first_raw ) ]; \
unsigned int size = bigint_required_size ( sizeof ( temp) ); \
bigint_t ( size ) first_temp; \
bigint_t ( size ) second_temp; \
{} /* Fix emacs alignment */ \
\
assert ( sizeof ( first_raw ) == sizeof ( temp ) ); \
assert ( sizeof ( second_raw ) == sizeof ( temp ) ); \
bigint_init ( &first_temp, first_raw, sizeof ( first_raw ) ); \
bigint_init ( &second_temp, second_raw, sizeof ( second_raw ) );\
bigint_swap ( &first_temp, &second_temp, 0 ); \
bigint_done ( &first_temp, temp, sizeof ( temp ) ); \
ok ( memcmp ( temp, first_raw, sizeof ( temp ) ) == 0 ); \
bigint_done ( &second_temp, temp, sizeof ( temp ) ); \
ok ( memcmp ( temp, second_raw, sizeof ( temp ) ) == 0 ); \
bigint_swap ( &first_temp, &second_temp, 1 ); \
bigint_done ( &first_temp, temp, sizeof ( temp ) ); \
ok ( memcmp ( temp, second_raw, sizeof ( temp ) ) == 0 ); \
bigint_done ( &second_temp, temp, sizeof ( temp ) ); \
ok ( memcmp ( temp, first_raw, sizeof ( temp ) ) == 0 ); \
bigint_swap ( &first_temp, &second_temp, 1 ); \
bigint_done ( &first_temp, temp, sizeof ( temp ) ); \
ok ( memcmp ( temp, first_raw, sizeof ( temp ) ) == 0 ); \
bigint_done ( &second_temp, temp, sizeof ( temp ) ); \
ok ( memcmp ( temp, second_raw, sizeof ( temp ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer multiplication test
*
* @v multiplicand Big integer to be multiplied
* @v multiplier Big integer to be multiplied
* @v expected Big integer expected result
*/
#define bigint_multiply_ok( multiplicand, multiplier, expected ) do { \
static const uint8_t multiplicand_raw[] = multiplicand; \
static const uint8_t multiplier_raw[] = multiplier; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int multiplicand_size = \
bigint_required_size ( sizeof ( multiplicand_raw ) ); \
unsigned int multiplier_size = \
bigint_required_size ( sizeof ( multiplier_raw ) ); \
bigint_t ( multiplicand_size ) multiplicand_temp; \
bigint_t ( multiplier_size ) multiplier_temp; \
bigint_t ( multiplicand_size + multiplier_size ) result_temp; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &result_temp ) == \
( bigint_size ( &multiplicand_temp ) + \
bigint_size ( &multiplier_temp ) ) ); \
bigint_init ( &multiplicand_temp, multiplicand_raw, \
sizeof ( multiplicand_raw ) ); \
bigint_init ( &multiplier_temp, multiplier_raw, \
sizeof ( multiplier_raw ) ); \
DBG ( "Multiply:\n" ); \
DBG_HDA ( 0, &multiplicand_temp, sizeof ( multiplicand_temp ) );\
DBG_HDA ( 0, &multiplier_temp, sizeof ( multiplier_temp ) ); \
bigint_multiply ( &multiplicand_temp, &multiplier_temp, \
&result_temp ); \
DBG_HDA ( 0, &result_temp, sizeof ( result_temp ) ); \
bigint_done ( &result_temp, result_raw, sizeof ( result_raw ) );\
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer modular direct reduction test
*
* @v modulus Big integer modulus
* @v value Big integer to be reduced
* @v expected Big integer expected result
*/
#define bigint_reduce_ok( modulus, value, expected ) do { \
static const uint8_t modulus_raw[] = modulus; \
static const uint8_t value_raw[] = value; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( modulus_raw ) ); \
bigint_t ( size ) modulus_temp; \
bigint_t ( size ) value_temp; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &modulus_temp ) == \
bigint_size ( &value_temp ) ); \
bigint_init ( &modulus_temp, modulus_raw, \
sizeof ( modulus_raw ) ); \
bigint_init ( &value_temp, value_raw, sizeof ( value_raw ) ); \
DBG ( "Modular reduce:\n" ); \
DBG_HDA ( 0, &modulus_temp, sizeof ( modulus_temp ) ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_reduce ( &modulus_temp, &value_temp ); \
DBG_HDA ( 0, &value_temp, sizeof ( value_temp ) ); \
bigint_done ( &value_temp, result_raw, sizeof ( result_raw ) ); \
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
\
bigint_init ( &value_temp, modulus_raw, \
sizeof ( modulus_raw ) ); \
ok ( memcmp ( &modulus_temp, &value_temp, \
sizeof ( modulus_temp ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer modular inversion test
*
* @v invertend Big integer to be inverted
* @v expected Big integer expected result
*/
#define bigint_mod_invert_ok( invertend, expected ) do { \
static const uint8_t invertend_raw[] = invertend; \
static const uint8_t expected_raw[] = expected; \
uint8_t inverse_raw[ sizeof ( expected_raw ) ]; \
unsigned int invertend_size = \
bigint_required_size ( sizeof ( invertend_raw ) ); \
unsigned int inverse_size = \
bigint_required_size ( sizeof ( inverse_raw ) ); \
bigint_t ( invertend_size ) invertend_temp; \
bigint_t ( inverse_size ) inverse_temp; \
{} /* Fix emacs alignment */ \
\
bigint_init ( &invertend_temp, invertend_raw, \
sizeof ( invertend_raw ) ); \
DBG ( "Modular invert:\n" ); \
DBG_HDA ( 0, &invertend_temp, sizeof ( invertend_temp ) ); \
bigint_mod_invert ( &invertend_temp, &inverse_temp ); \
DBG_HDA ( 0, &inverse_temp, sizeof ( inverse_temp ) ); \
bigint_done ( &inverse_temp, inverse_raw, \
sizeof ( inverse_raw ) ); \
\
ok ( memcmp ( inverse_raw, expected_raw, \
sizeof ( inverse_raw ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer modular multiplication test
*
* @v multiplicand Big integer to be multiplied
* @v multiplier Big integer to be multiplied
* @v modulus Big integer modulus
* @v expected Big integer expected result
*/
#define bigint_mod_multiply_ok( multiplicand, multiplier, modulus, \
expected ) do { \
static const uint8_t multiplicand_raw[] = multiplicand; \
static const uint8_t multiplier_raw[] = multiplier; \
static const uint8_t modulus_raw[] = modulus; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( multiplicand_raw ) ); \
bigint_t ( size ) multiplicand_temp; \
bigint_t ( size ) multiplier_temp; \
bigint_t ( size ) modulus_temp; \
bigint_t ( size ) result_temp; \
size_t tmp_len = bigint_mod_multiply_tmp_len ( &modulus_temp ); \
uint8_t tmp[tmp_len]; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &multiplier_temp ) == \
bigint_size ( &multiplicand_temp ) ); \
assert ( bigint_size ( &multiplier_temp ) == \
bigint_size ( &modulus_temp ) ); \
assert ( bigint_size ( &multiplier_temp ) == \
bigint_size ( &result_temp ) ); \
bigint_init ( &multiplicand_temp, multiplicand_raw, \
sizeof ( multiplicand_raw ) ); \
bigint_init ( &multiplier_temp, multiplier_raw, \
sizeof ( multiplier_raw ) ); \
bigint_init ( &modulus_temp, modulus_raw, \
sizeof ( modulus_raw ) ); \
DBG ( "Modular multiply:\n" ); \
DBG_HDA ( 0, &multiplicand_temp, sizeof ( multiplicand_temp ) );\
DBG_HDA ( 0, &multiplier_temp, sizeof ( multiplier_temp ) ); \
DBG_HDA ( 0, &modulus_temp, sizeof ( modulus_temp ) ); \
bigint_mod_multiply ( &multiplicand_temp, &multiplier_temp, \
&modulus_temp, &result_temp, tmp ); \
DBG_HDA ( 0, &result_temp, sizeof ( result_temp ) ); \
bigint_done ( &result_temp, result_raw, sizeof ( result_raw ) );\
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
} while ( 0 )
/**
* Report result of big integer modular exponentiation test
*
* @v base Big integer base
* @v modulus Big integer modulus
* @v exponent Big integer exponent
* @v expected Big integer expected result
*/
#define bigint_mod_exp_ok( base, modulus, exponent, expected ) do { \
static const uint8_t base_raw[] = base; \
static const uint8_t modulus_raw[] = modulus; \
static const uint8_t exponent_raw[] = exponent; \
static const uint8_t expected_raw[] = expected; \
uint8_t result_raw[ sizeof ( expected_raw ) ]; \
unsigned int size = \
bigint_required_size ( sizeof ( base_raw ) ); \
unsigned int exponent_size = \
bigint_required_size ( sizeof ( exponent_raw ) ); \
bigint_t ( size ) base_temp; \
bigint_t ( size ) modulus_temp; \
bigint_t ( exponent_size ) exponent_temp; \
bigint_t ( size ) result_temp; \
size_t tmp_len = bigint_mod_exp_tmp_len ( &modulus_temp, \
&exponent_temp ); \
uint8_t tmp[tmp_len]; \
{} /* Fix emacs alignment */ \
\
assert ( bigint_size ( &modulus_temp ) == \
bigint_size ( &base_temp ) ); \
assert ( bigint_size ( &modulus_temp ) == \
bigint_size ( &result_temp ) ); \
bigint_init ( &base_temp, base_raw, sizeof ( base_raw ) ); \
bigint_init ( &modulus_temp, modulus_raw, \
sizeof ( modulus_raw ) ); \
bigint_init ( &exponent_temp, exponent_raw, \
sizeof ( exponent_raw ) ); \
DBG ( "Modular exponentiation:\n" ); \
DBG_HDA ( 0, &base_temp, sizeof ( base_temp ) ); \
DBG_HDA ( 0, &modulus_temp, sizeof ( modulus_temp ) ); \
DBG_HDA ( 0, &exponent_temp, sizeof ( exponent_temp ) ); \
bigint_mod_exp ( &base_temp, &modulus_temp, &exponent_temp, \
&result_temp, tmp ); \
DBG_HDA ( 0, &result_temp, sizeof ( result_temp ) ); \
bigint_done ( &result_temp, result_raw, sizeof ( result_raw ) );\
\
ok ( memcmp ( result_raw, expected_raw, \
sizeof ( result_raw ) ) == 0 ); \
} while ( 0 )
/**
* Perform big integer self-tests
*
*/
static void bigint_test_exec ( void ) {
bigint_add_ok ( BIGINT ( 0x8a ),
BIGINT ( 0x43 ),
BIGINT ( 0xcd ), 0 );
bigint_add_ok ( BIGINT ( 0xc5, 0x7b ),
BIGINT ( 0xd6, 0xb1 ),
BIGINT ( 0x9c, 0x2c ), 1 );
bigint_add_ok ( BIGINT ( 0xf9, 0xd9, 0xdc ),
BIGINT ( 0x6d, 0x4b, 0xca ),
BIGINT ( 0x67, 0x25, 0xa6 ), 1 );
bigint_add_ok ( BIGINT ( 0xdd, 0xc2, 0x20, 0x5f ),
BIGINT ( 0x80, 0x32, 0xc4, 0xb0 ),
BIGINT ( 0x5d, 0xf4, 0xe5, 0x0f ), 1 );
bigint_add_ok ( BIGINT ( 0x5e, 0x46, 0x4d, 0xc6, 0xa2, 0x7d, 0x45,
0xc3 ),
BIGINT ( 0xd6, 0xc0, 0xd7, 0xd4, 0xf6, 0x04, 0x47,
0xed ),
BIGINT ( 0x35, 0x07, 0x25, 0x9b, 0x98, 0x81, 0x8d,
0xb0 ), 1 );
bigint_add_ok ( BIGINT ( 0x0e, 0x46, 0x4d, 0xc6, 0xa2, 0x7d, 0x45,
0xc3 ),
BIGINT ( 0xd6, 0xc0, 0xd7, 0xd4, 0xf6, 0x04, 0x47,
0xed ),
BIGINT ( 0xe5, 0x07, 0x25, 0x9b, 0x98, 0x81, 0x8d,
0xb0 ), 0 );
bigint_add_ok ( BIGINT ( 0x01, 0xed, 0x45, 0x4b, 0x41, 0xeb, 0x4c,
0x2e, 0x53, 0x07, 0x15, 0x51, 0x56, 0x47,
0x29, 0xfc, 0x9c, 0xbd, 0xbd, 0xfb, 0x1b,
0xd1, 0x1d ),
BIGINT ( 0x73, 0xed, 0xfc, 0x35, 0x31, 0x22, 0xd7,
0xb1, 0xea, 0x91, 0x5a, 0xe4, 0xba, 0xbc,
0xa1, 0x38, 0x72, 0xae, 0x4b, 0x1c, 0xc1,
0x05, 0xb3 ),
BIGINT ( 0x75, 0xdb, 0x41, 0x80, 0x73, 0x0e, 0x23,
0xe0, 0x3d, 0x98, 0x70, 0x36, 0x11, 0x03,
0xcb, 0x35, 0x0f, 0x6c, 0x09, 0x17, 0xdc,
0xd6, 0xd0 ), 0 );
bigint_add_ok ( BIGINT ( 0x06, 0x8e, 0xd6, 0x18, 0xbb, 0x4b, 0x0c,
0xc5, 0x85, 0xde, 0xee, 0x9b, 0x3f, 0x65,
0x63, 0x86, 0xf5, 0x5a, 0x9f, 0xa2, 0xd7,
0xb2, 0xc7, 0xb6, 0x1d, 0x28, 0x6c, 0x50,
0x47, 0x10, 0x0a, 0x0e, 0x86, 0xcd, 0x2a,
0x64, 0xdc, 0xe6, 0x9d, 0x96, 0xd8, 0xf4,
0x56, 0x46, 0x6f, 0xbb, 0x7b, 0x64, 0x6f,
0xdc, 0x2a, 0xd1, 0x3b, 0xcc, 0x03, 0x85,
0x95, 0xf4, 0xe9, 0x68, 0x1f, 0x5c, 0xc5,
0xbf, 0x97, 0x19, 0x12, 0x88, 0x2e, 0x88,
0xb9, 0x34, 0xac, 0x74, 0x83, 0x2d, 0x8f,
0xb3, 0x97, 0x53, 0x99, 0xf3, 0xb4, 0x8b,
0x2d, 0x98, 0x69, 0x8d, 0x19, 0xf0, 0x40,
0x66, 0x3f, 0x60, 0x78, 0x34, 0x7f, 0x9b,
0xf7, 0x01, 0x74, 0x55, 0xca, 0x63, 0x25,
0x7b, 0x86, 0xe9, 0x73, 0xfd, 0x5d, 0x77,
0x32, 0x5e, 0x9e, 0x42, 0x53, 0xb6, 0x35,
0x92, 0xb9, 0xd7, 0x1b, 0xf7, 0x16, 0x55,
0xf6, 0xe2 ),
BIGINT ( 0x3f, 0x8f, 0x62, 0x21, 0x4a, 0x7a, 0xa2,
0xef, 0xa8, 0x79, 0x9b, 0x73, 0xac, 0xde,
0x72, 0xe4, 0xfc, 0x3c, 0xd3, 0xa9, 0x44,
0x1a, 0x6a, 0x02, 0x76, 0xe3, 0x78, 0x4d,
0x2e, 0x07, 0x9b, 0xb6, 0x3d, 0x5d, 0xc5,
0xcd, 0x68, 0x23, 0x4b, 0x5f, 0x89, 0x0e,
0xd7, 0xa7, 0xff, 0x18, 0x80, 0xdc, 0xfb,
0x34, 0x45, 0xca, 0x4b, 0xdb, 0x8a, 0x19,
0xcb, 0xc9, 0xe5, 0xa1, 0x63, 0xa2, 0x0d,
0x56, 0xc4, 0xf9, 0x51, 0x1b, 0x88, 0x4e,
0x36, 0xab, 0x15, 0x4d, 0x8f, 0xdc, 0x08,
0xc4, 0x4d, 0x43, 0xc7, 0x2b, 0xc9, 0x5c,
0x05, 0x26, 0xe3, 0x46, 0xf0, 0x64, 0xaa,
0x02, 0xa4, 0xbe, 0x3a, 0xd1, 0xca, 0x07,
0x6a, 0x6e, 0x62, 0xf4, 0x57, 0x71, 0x96,
0xec, 0xf0, 0x0b, 0xac, 0xa4, 0x4a, 0xa3,
0x6d, 0x01, 0xba, 0xbd, 0x62, 0xc0, 0x10,
0x54, 0x33, 0x8a, 0x71, 0xef, 0xaa, 0x1c,
0x25, 0x25 ),
BIGINT ( 0x46, 0x1e, 0x38, 0x3a, 0x05, 0xc5, 0xaf,
0xb5, 0x2e, 0x58, 0x8a, 0x0e, 0xec, 0x43,
0xd6, 0x6b, 0xf1, 0x97, 0x73, 0x4c, 0x1b,
0xcd, 0x31, 0xb8, 0x94, 0x0b, 0xe4, 0x9d,
0x75, 0x17, 0xa5, 0xc4, 0xc4, 0x2a, 0xf0,
0x32, 0x45, 0x09, 0xe8, 0xf6, 0x62, 0x03,
0x2d, 0xee, 0x6e, 0xd3, 0xfc, 0x41, 0x6b,
0x10, 0x70, 0x9b, 0x87, 0xa7, 0x8d, 0x9f,
0x61, 0xbe, 0xcf, 0x09, 0x82, 0xfe, 0xd3,
0x16, 0x5c, 0x12, 0x63, 0xa3, 0xb6, 0xd6,
0xef, 0xdf, 0xc1, 0xc2, 0x13, 0x09, 0x98,
0x77, 0xe4, 0x97, 0x61, 0x1f, 0x7d, 0xe7,
0x32, 0xbf, 0x4c, 0xd4, 0x0a, 0x54, 0xea,
0x68, 0xe4, 0x1e, 0xb3, 0x06, 0x49, 0xa3,
0x61, 0x6f, 0xd7, 0x4a, 0x21, 0xd4, 0xbc,
0x68, 0x76, 0xf5, 0x20, 0xa1, 0xa8, 0x1a,
0x9f, 0x60, 0x58, 0xff, 0xb6, 0x76, 0x45,
0xe6, 0xed, 0x61, 0x8d, 0xe6, 0xc0, 0x72,
0x1c, 0x07 ), 0 );
bigint_subtract_ok ( BIGINT ( 0x83 ),
BIGINT ( 0x50 ),
BIGINT ( 0xcd ), 1 );
bigint_subtract_ok ( BIGINT ( 0x2c, 0x7c ),
BIGINT ( 0x49, 0x0e ),
BIGINT ( 0x1c, 0x92 ), 0 );
bigint_subtract_ok ( BIGINT ( 0x9c, 0x30, 0xbf ),
BIGINT ( 0xde, 0x4e, 0x07 ),
BIGINT ( 0x42, 0x1d, 0x48 ), 0 );
bigint_subtract_ok ( BIGINT ( 0xbb, 0x77, 0x32, 0x5a ),
BIGINT ( 0x5a, 0xd5, 0xfe, 0x28 ),
BIGINT ( 0x9f, 0x5e, 0xcb, 0xce ), 1 );
bigint_subtract_ok ( BIGINT ( 0x00, 0x00, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff ),
BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x2a ),
BIGINT ( 0xff, 0xff, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x2b ), 1 );
bigint_subtract_ok ( BIGINT ( 0x7b, 0xaa, 0x16, 0xcf, 0x15, 0x87,
0xe0, 0x4f, 0x2c, 0xa3, 0xec, 0x2f,
0x46, 0xfb, 0x83, 0xc6, 0xe0, 0xee,
0x57, 0xfa, 0x04, 0xce, 0xa6 ),
BIGINT ( 0x46, 0x55, 0xb6, 0x23, 0x63, 0xd0,
0x55, 0xdb, 0x8f, 0xcc, 0x55, 0xa8,
0x2f, 0x85, 0xc1, 0x9f, 0x2c, 0x13,
0x10, 0x9e, 0x76, 0x3c, 0x11 ),
BIGINT ( 0xca, 0xab, 0x9f, 0x54, 0x4e, 0x48,
0x75, 0x8c, 0x63, 0x28, 0x69, 0x78,
0xe8, 0x8a, 0x3d, 0xd8, 0x4b, 0x24,
0xb8, 0xa4, 0x71, 0x6d, 0x6b ), 1 );
bigint_subtract_ok ( BIGINT ( 0x5b, 0x06, 0x77, 0x7b, 0xfd, 0x34,
0x5f, 0x0f, 0xd9, 0xbd, 0x8e, 0x5d,
0xc8, 0x4a, 0x70, 0x95, 0x1b, 0xb6,
0x48, 0xfb, 0x0e, 0x40, 0xce, 0x06,
0x66, 0xcc, 0x29, 0xe9, 0x51, 0x59,
0x59, 0xc9, 0x65, 0x07, 0x75, 0xb8,
0xd4, 0xcb, 0x07, 0x68, 0x14, 0x48,
0xc7, 0x1e, 0xfe, 0xb3, 0x4c, 0xf1,
0x10, 0xf0, 0xc7, 0x82, 0x38, 0x4c,
0xaf, 0x05, 0x6d, 0x91, 0xc5, 0x18,
0xfd, 0x1e, 0x26, 0x1b, 0xef, 0x71,
0x70, 0x2e, 0x06, 0x70, 0x8e, 0x54,
0xfa, 0x2b, 0x4d, 0x96, 0x85, 0x10,
0x03, 0x76, 0xe7, 0x17, 0x59, 0x86,
0x6c, 0x8b, 0x24, 0x6e, 0xd9, 0x30,
0xf3, 0xd2, 0x9b, 0x62, 0xdc, 0x23,
0x54, 0x06, 0x51, 0xb1, 0x95, 0x58,
0xec, 0x27, 0xf6, 0x19, 0xae, 0xf4,
0x31, 0xec, 0x72, 0x53, 0xcd, 0x32,
0xed, 0xf4, 0x25, 0x4a, 0x5b, 0x36,
0xa2, 0xb4, 0xa0, 0x29, 0x0c, 0x6b,
0x3f, 0xc2 ),
BIGINT ( 0x7a, 0xd4, 0x25, 0xf1, 0xb5, 0xf5,
0x00, 0x96, 0x47, 0x5b, 0x4f, 0x9f,
0x1f, 0x61, 0x69, 0xd9, 0x72, 0x47,
0xde, 0xbd, 0x87, 0x5d, 0x50, 0x91,
0x69, 0xd8, 0x35, 0xe0, 0x43, 0xd8,
0xd5, 0x15, 0xf2, 0xcd, 0x01, 0x73,
0x0d, 0x34, 0xf0, 0x34, 0x46, 0x76,
0xc0, 0x55, 0x7b, 0x27, 0xf5, 0x7b,
0x55, 0xe9, 0xd0, 0x29, 0x0b, 0x4b,
0x9f, 0x07, 0xbf, 0x2c, 0x3f, 0xef,
0x36, 0x34, 0xde, 0x29, 0x1d, 0x5d,
0x84, 0x5a, 0x5d, 0xc1, 0x02, 0x4d,
0x56, 0xf1, 0x47, 0x39, 0x37, 0xc9,
0xb5, 0x5f, 0x73, 0xec, 0x7c, 0x3d,
0xbd, 0xc0, 0xfd, 0x38, 0x6c, 0x91,
0x88, 0x4a, 0x0f, 0xee, 0xa1, 0x80,
0xf5, 0x6a, 0x7c, 0x8c, 0x02, 0xc3,
0x5a, 0xb2, 0x15, 0xa6, 0x2f, 0x6b,
0x5b, 0x78, 0xb5, 0xf3, 0xbd, 0xd0,
0xc8, 0xbc, 0xb1, 0xbb, 0xe1, 0xce,
0x22, 0x80, 0x34, 0x5a, 0x2a, 0x27,
0x83, 0xdc ),
BIGINT ( 0x1f, 0xcd, 0xae, 0x75, 0xb8, 0xc0,
0xa1, 0x86, 0x6d, 0x9d, 0xc1, 0x41,
0x57, 0x16, 0xf9, 0x44, 0x56, 0x91,
0x95, 0xc2, 0x79, 0x1c, 0x82, 0x8b,
0x03, 0x0c, 0x0b, 0xf6, 0xf2, 0x7f,
0x7b, 0x4c, 0x8d, 0xc5, 0x8b, 0xba,
0x38, 0x69, 0xe8, 0xcc, 0x32, 0x2d,
0xf9, 0x36, 0x7c, 0x74, 0xa8, 0x8a,
0x44, 0xf9, 0x08, 0xa6, 0xd2, 0xfe,
0xf0, 0x02, 0x51, 0x9a, 0x7a, 0xd6,
0x39, 0x16, 0xb8, 0x0d, 0x2d, 0xec,
0x14, 0x2c, 0x57, 0x50, 0x73, 0xf8,
0x5c, 0xc5, 0xf9, 0xa2, 0xb2, 0xb9,
0xb1, 0xe8, 0x8c, 0xd5, 0x22, 0xb7,
0x51, 0x35, 0xd8, 0xc9, 0x93, 0x60,
0x94, 0x77, 0x74, 0x8b, 0xc5, 0x5d,
0xa1, 0x64, 0x2a, 0xda, 0x6d, 0x6a,
0x6e, 0x8a, 0x1f, 0x8c, 0x80, 0x77,
0x29, 0x8c, 0x43, 0x9f, 0xf0, 0x9d,
0xda, 0xc8, 0x8c, 0x71, 0x86, 0x97,
0x7f, 0xcb, 0x94, 0x31, 0x1d, 0xbc,
0x44, 0x1a ), 0 );
bigint_shl_ok ( BIGINT ( 0xe0 ),
BIGINT ( 0xc0 ) );
bigint_shl_ok ( BIGINT ( 0x43, 0x1d ),
BIGINT ( 0x86, 0x3a ) );
bigint_shl_ok ( BIGINT ( 0xac, 0xed, 0x9b ),
BIGINT ( 0x59, 0xdb, 0x36 ) );
bigint_shl_ok ( BIGINT ( 0x2c, 0xe8, 0x3a, 0x22 ),
BIGINT ( 0x59, 0xd0, 0x74, 0x44 ) );
bigint_shl_ok ( BIGINT ( 0x4e, 0x88, 0x4a, 0x05, 0x5e, 0x10, 0xee,
0x5b, 0xc6, 0x40, 0x0e, 0x03, 0xd7, 0x0d,
0x28, 0xa5, 0x55, 0xb2, 0x50, 0xef, 0x69,
0xd1, 0x1d ),
BIGINT ( 0x9d, 0x10, 0x94, 0x0a, 0xbc, 0x21, 0xdc,
0xb7, 0x8c, 0x80, 0x1c, 0x07, 0xae, 0x1a,
0x51, 0x4a, 0xab, 0x64, 0xa1, 0xde, 0xd3,
0xa2, 0x3a ) );
bigint_shl_ok ( BIGINT ( 0x07, 0x62, 0x78, 0x70, 0x2e, 0xd4, 0x41,
0xaa, 0x9b, 0x50, 0xb1, 0x9a, 0x71, 0xf5,
0x1c, 0x2f, 0xe7, 0x0d, 0xf1, 0x46, 0x57,
0x04, 0x99, 0x78, 0x4e, 0x84, 0x78, 0xba,
0x57, 0xea, 0xa5, 0x43, 0xf7, 0x02, 0xf0,
0x7a, 0x22, 0x60, 0x65, 0x42, 0xf2, 0x33,
0x7d, 0xe3, 0xa8, 0x1b, 0xc4, 0x14, 0xdb,
0xee, 0x4a, 0xf1, 0xe1, 0x52, 0xd4, 0xda,
0x23, 0xed, 0x13, 0x5d, 0xea, 0xcf, 0xf6,
0x5e, 0x39, 0x84, 0xe2, 0xb3, 0xa2, 0x05,
0xba, 0xd9, 0x49, 0x8e, 0x75, 0x1d, 0xdb,
0xe6, 0xb1, 0x6e, 0xda, 0x0a, 0x83, 0xd0,
0x6e, 0xcf, 0x7a, 0x66, 0xb7, 0x64, 0x84,
0xf5, 0x09, 0x5a, 0xa8, 0x11, 0x93, 0xf3,
0x4f, 0x02, 0x28, 0x00, 0x3a, 0xf0, 0xa9,
0x08, 0x77, 0x04, 0xf5, 0x04, 0xcd, 0x6b,
0x24, 0xbe, 0x0f, 0x6d, 0xe3, 0xb2, 0xd3,
0x07, 0x68, 0xe9, 0x00, 0x59, 0xa0, 0xe4,
0x9e, 0x5e ),
BIGINT ( 0x0e, 0xc4, 0xf0, 0xe0, 0x5d, 0xa8, 0x83,
0x55, 0x36, 0xa1, 0x63, 0x34, 0xe3, 0xea,
0x38, 0x5f, 0xce, 0x1b, 0xe2, 0x8c, 0xae,
0x09, 0x32, 0xf0, 0x9d, 0x08, 0xf1, 0x74,
0xaf, 0xd5, 0x4a, 0x87, 0xee, 0x05, 0xe0,
0xf4, 0x44, 0xc0, 0xca, 0x85, 0xe4, 0x66,
0xfb, 0xc7, 0x50, 0x37, 0x88, 0x29, 0xb7,
0xdc, 0x95, 0xe3, 0xc2, 0xa5, 0xa9, 0xb4,
0x47, 0xda, 0x26, 0xbb, 0xd5, 0x9f, 0xec,
0xbc, 0x73, 0x09, 0xc5, 0x67, 0x44, 0x0b,
0x75, 0xb2, 0x93, 0x1c, 0xea, 0x3b, 0xb7,
0xcd, 0x62, 0xdd, 0xb4, 0x15, 0x07, 0xa0,
0xdd, 0x9e, 0xf4, 0xcd, 0x6e, 0xc9, 0x09,
0xea, 0x12, 0xb5, 0x50, 0x23, 0x27, 0xe6,
0x9e, 0x04, 0x50, 0x00, 0x75, 0xe1, 0x52,
0x10, 0xee, 0x09, 0xea, 0x09, 0x9a, 0xd6,
0x49, 0x7c, 0x1e, 0xdb, 0xc7, 0x65, 0xa6,
0x0e, 0xd1, 0xd2, 0x00, 0xb3, 0x41, 0xc9,
0x3c, 0xbc ) );
bigint_shr_ok ( BIGINT ( 0x8f ),
BIGINT ( 0x47 ) );
bigint_shr_ok ( BIGINT ( 0xaa, 0x1d ),
BIGINT ( 0x55, 0x0e ) );
bigint_shr_ok ( BIGINT ( 0xf0, 0xbd, 0x68 ),
BIGINT ( 0x78, 0x5e, 0xb4 ) );
bigint_shr_ok ( BIGINT ( 0x33, 0xa0, 0x3d, 0x95 ),
BIGINT ( 0x19, 0xd0, 0x1e, 0xca ) );
bigint_shr_ok ( BIGINT ( 0xa1, 0xf4, 0xb9, 0x64, 0x91, 0x99, 0xa1,
0xf4, 0xae, 0xeb, 0x71, 0x97, 0x1b, 0x71,
0x09, 0x38, 0x3f, 0x8f, 0xc5, 0x3a, 0xb9,
0x75, 0x94 ),
BIGINT ( 0x50, 0xfa, 0x5c, 0xb2, 0x48, 0xcc, 0xd0,
0xfa, 0x57, 0x75, 0xb8, 0xcb, 0x8d, 0xb8,
0x84, 0x9c, 0x1f, 0xc7, 0xe2, 0x9d, 0x5c,
0xba, 0xca ) );
bigint_shr_ok ( BIGINT ( 0xc0, 0xb3, 0x78, 0x46, 0x69, 0x6e, 0x35,
0x94, 0xed, 0x28, 0xdc, 0xfd, 0xf6, 0xdb,
0x2d, 0x24, 0xcb, 0xa4, 0x6f, 0x0e, 0x58,
0x89, 0x04, 0xec, 0xc8, 0x0c, 0x2d, 0xb3,
0x58, 0xa7, 0x22, 0x6d, 0x93, 0xe0, 0xb8,
0x48, 0x6a, 0x3f, 0x04, 0x7e, 0xbe, 0xb8,
0xa7, 0x84, 0xf5, 0xc9, 0x2f, 0x60, 0x9e,
0x7c, 0xbc, 0xaf, 0x28, 0x89, 0x2f, 0xaa,
0xd1, 0x82, 0x77, 0xa4, 0xdf, 0xf3, 0x4a,
0xc6, 0xed, 0xa3, 0x07, 0xb4, 0xa9, 0xfd,
0xef, 0xf8, 0x20, 0xb9, 0xb3, 0xff, 0x35,
0x27, 0xed, 0x02, 0xea, 0xec, 0x63, 0xc0,
0x46, 0x97, 0xc0, 0x4c, 0xca, 0x89, 0xca,
0x14, 0xe8, 0xe0, 0x02, 0x14, 0x44, 0x46,
0xf3, 0x2f, 0xbc, 0x6a, 0x28, 0xa2, 0xbe,
0x20, 0xc8, 0xaa, 0x0f, 0xd9, 0x51, 0x8e,
0x8d, 0x51, 0x29, 0x61, 0xef, 0x48, 0xae,
0x3e, 0xe5, 0x10, 0xbf, 0xda, 0x9b, 0x92,
0xb3, 0x77 ),
BIGINT ( 0x60, 0x59, 0xbc, 0x23, 0x34, 0xb7, 0x1a,
0xca, 0x76, 0x94, 0x6e, 0x7e, 0xfb, 0x6d,
0x96, 0x92, 0x65, 0xd2, 0x37, 0x87, 0x2c,
0x44, 0x82, 0x76, 0x64, 0x06, 0x16, 0xd9,
0xac, 0x53, 0x91, 0x36, 0xc9, 0xf0, 0x5c,
0x24, 0x35, 0x1f, 0x82, 0x3f, 0x5f, 0x5c,
0x53, 0xc2, 0x7a, 0xe4, 0x97, 0xb0, 0x4f,
0x3e, 0x5e, 0x57, 0x94, 0x44, 0x97, 0xd5,
0x68, 0xc1, 0x3b, 0xd2, 0x6f, 0xf9, 0xa5,
0x63, 0x76, 0xd1, 0x83, 0xda, 0x54, 0xfe,
0xf7, 0xfc, 0x10, 0x5c, 0xd9, 0xff, 0x9a,
0x93, 0xf6, 0x81, 0x75, 0x76, 0x31, 0xe0,
0x23, 0x4b, 0xe0, 0x26, 0x65, 0x44, 0xe5,
0x0a, 0x74, 0x70, 0x01, 0x0a, 0x22, 0x23,
0x79, 0x97, 0xde, 0x35, 0x14, 0x51, 0x5f,
0x10, 0x64, 0x55, 0x07, 0xec, 0xa8, 0xc7,
0x46, 0xa8, 0x94, 0xb0, 0xf7, 0xa4, 0x57,
0x1f, 0x72, 0x88, 0x5f, 0xed, 0x4d, 0xc9,
0x59, 0xbb ) );
bigint_is_zero_ok ( BIGINT ( 0x9b ),
0 );
bigint_is_zero_ok ( BIGINT ( 0x5a, 0x9d ),
0 );
bigint_is_zero_ok ( BIGINT ( 0x5f, 0x80, 0x78 ),
0 );
bigint_is_zero_ok ( BIGINT ( 0xa0, 0x52, 0x47, 0x2e ),
0 );
bigint_is_zero_ok ( BIGINT ( 0x18, 0x08, 0x49, 0xdb, 0x7b, 0x5c,
0xe7, 0x41, 0x07, 0xdf, 0xed, 0xf9,
0xd3, 0x92, 0x0d, 0x75, 0xa6, 0xb0,
0x14, 0xfa, 0xdd, 0xfd, 0x82 ),
0 );
bigint_is_zero_ok ( BIGINT ( 0x04, 0x04, 0xb5, 0xf5, 0x01, 0xae,
0x2b, 0x91, 0xa7, 0xc1, 0x49, 0x97,
0x3f, 0x45, 0x53, 0x52, 0xb8, 0x52,
0xf1, 0x62, 0xa5, 0x21, 0x18, 0xd4,
0xb0, 0xb4, 0x8a, 0x17, 0x0e, 0xe8,
0xeb, 0xaa, 0x28, 0xae, 0x3d, 0x8e,
0xe3, 0x6c, 0xd0, 0x01, 0x0c, 0x54,
0xca, 0x23, 0xbb, 0x06, 0xcd, 0x7a,
0x61, 0x89, 0x38, 0x34, 0x6e, 0xc7,
0xc2, 0xee, 0xb1, 0x80, 0x61, 0x0e,
0xc6, 0x8d, 0x65, 0xa0, 0xeb, 0x34,
0xe9, 0x63, 0x09, 0x4c, 0x20, 0xac,
0x42, 0xe3, 0x35, 0xa2, 0x3e, 0x3b,
0x2e, 0x18, 0x70, 0x45, 0x7c, 0xab,
0x42, 0xcc, 0xe0, 0x9e, 0x7c, 0x42,
0xd1, 0xda, 0x6c, 0x51, 0x10, 0x1e,
0x0e, 0x3f, 0xe5, 0xd6, 0xd8, 0x56,
0x08, 0xb2, 0x3b, 0x15, 0xc4, 0x7c,
0x0c, 0x7e, 0xaf, 0x7b, 0x9d, 0xd6,
0x2b, 0xc0, 0x2f, 0xa2, 0xa3, 0xa3,
0x77, 0x58, 0x1b, 0xe9, 0xa8, 0x9a,
0x23, 0x7f ),
0 );
bigint_is_zero_ok ( BIGINT ( 0x00 ),
1 );
bigint_is_zero_ok ( BIGINT ( 0x00, 0x00 ),
1 );
bigint_is_zero_ok ( BIGINT ( 0x00, 0x00, 0x00 ),
1 );
bigint_is_zero_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00 ),
1 );
bigint_is_zero_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00 ),
1 );
bigint_is_zero_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00 ),
1 );
bigint_is_zero_ok ( BIGINT ( 0xff ),
0 );
bigint_is_zero_ok ( BIGINT ( 0xff, 0xff ),
0 );
bigint_is_zero_ok ( BIGINT ( 0xff, 0xff, 0xff ),
0 );
bigint_is_zero_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff ),
0 );
bigint_is_zero_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff ),
0 );
bigint_is_zero_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff ),
0 );
bigint_is_geq_ok ( BIGINT ( 0xa2 ),
BIGINT ( 0x58 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0x58 ),
BIGINT ( 0xa2 ),
0 );
bigint_is_geq_ok ( BIGINT ( 0xa2 ),
BIGINT ( 0xa2 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0x61, 0x29 ),
BIGINT ( 0x87, 0xac ),
0 );
bigint_is_geq_ok ( BIGINT ( 0x87, 0xac ),
BIGINT ( 0x61, 0x29 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0x61, 0x29 ),
BIGINT ( 0x61, 0x29 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0xe6, 0x63, 0x14 ),
BIGINT ( 0xb7, 0x2b, 0x76 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0xb7, 0x2b, 0x76 ),
BIGINT ( 0xe6, 0x63, 0x14 ),
0 );
bigint_is_geq_ok ( BIGINT ( 0xe6, 0x63, 0x14 ),
BIGINT ( 0xe6, 0x63, 0x14 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0xe7, 0x4f, 0xd4, 0x80 ),
BIGINT ( 0xb5, 0xf9, 0x9b, 0x90 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0xb5, 0xf9, 0x9b, 0x90 ),
BIGINT ( 0xe7, 0x4f, 0xd4, 0x80 ),
0 );
bigint_is_geq_ok ( BIGINT ( 0xe7, 0x4f, 0xd4, 0x80 ),
BIGINT ( 0xe7, 0x4f, 0xd4, 0x80 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0xe6, 0x2c, 0x7c, 0x24, 0x78, 0x8f, 0x12,
0x20, 0xde, 0xd3, 0x6b, 0xc9, 0x97, 0x2d,
0x66, 0x74, 0xe5, 0xb6, 0xf7, 0x8f, 0x2b,
0x60, 0x98 ),
BIGINT ( 0x77, 0xbc, 0x3b, 0x1b, 0x57, 0x43, 0x3b,
0x8c, 0x82, 0xda, 0xb5, 0xc7, 0x18, 0x09,
0xb3, 0x59, 0x0e, 0x53, 0x2a, 0xb9, 0xd8,
0xa2, 0xb4 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0x77, 0xbc, 0x3b, 0x1b, 0x57, 0x43, 0x3b,
0x8c, 0x82, 0xda, 0xb5, 0xc7, 0x18, 0x09,
0xb3, 0x59, 0x0e, 0x53, 0x2a, 0xb9, 0xd8,
0xa2, 0xb4 ),
BIGINT ( 0xe6, 0x2c, 0x7c, 0x24, 0x78, 0x8f, 0x12,
0x20, 0xde, 0xd3, 0x6b, 0xc9, 0x97, 0x2d,
0x66, 0x74, 0xe5, 0xb6, 0xf7, 0x8f, 0x2b,
0x60, 0x98 ),
0 );
bigint_is_geq_ok ( BIGINT ( 0xe6, 0x2c, 0x7c, 0x24, 0x78, 0x8f, 0x12,
0x20, 0xde, 0xd3, 0x6b, 0xc9, 0x97, 0x2d,
0x66, 0x74, 0xe5, 0xb6, 0xf7, 0x8f, 0x2b,
0x60, 0x98 ),
BIGINT ( 0xe6, 0x2c, 0x7c, 0x24, 0x78, 0x8f, 0x12,
0x20, 0xde, 0xd3, 0x6b, 0xc9, 0x97, 0x2d,
0x66, 0x74, 0xe5, 0xb6, 0xf7, 0x8f, 0x2b,
0x60, 0x98 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0x2a, 0x98, 0xfd, 0x87, 0x5d, 0x9f, 0xb4,
0x8b, 0x5c, 0xcd, 0x5f, 0xcd, 0x53, 0xb3,
0xd1, 0x81, 0x6a, 0x9c, 0x93, 0x66, 0x40,
0xa7, 0x64, 0xe0, 0x8c, 0xec, 0x96, 0x63,
0x4d, 0x29, 0xfa, 0xb1, 0x5d, 0x93, 0x2f,
0xf9, 0x36, 0xea, 0x3b, 0xc1, 0xaf, 0x85,
0xcb, 0xde, 0x2d, 0xc8, 0x48, 0x33, 0xce,
0x7b, 0xa4, 0xa4, 0xda, 0x0f, 0xaa, 0x1b,
0xcb, 0xed, 0xbe, 0x3a, 0xa5, 0xbb, 0x73,
0x28, 0x04, 0xc6, 0x2a, 0xfb, 0x3a, 0xc3,
0xae, 0x42, 0x1f, 0x53, 0x6c, 0xb2, 0x76,
0xb7, 0xe2, 0x88, 0xcb, 0x88, 0xcf, 0xf0,
0x52, 0x81, 0xd3, 0xb2, 0x1f, 0x56, 0xe1,
0xe1, 0x47, 0x93, 0x6f, 0x2b, 0x49, 0xaa,
0x50, 0x99, 0x7a, 0xc4, 0x56, 0xb7, 0x13,
0x80, 0xf4, 0x73, 0x88, 0xc7, 0x39, 0x83,
0x67, 0xc7, 0xcc, 0xb2, 0x28, 0x7a, 0xd3,
0xdc, 0x48, 0xea, 0x62, 0x0d, 0xf5, 0x5a,
0x27, 0x96 ),
BIGINT ( 0xd4, 0x6b, 0x0a, 0x2e, 0x9f, 0xde, 0x4b,
0x64, 0xfa, 0x6b, 0x37, 0x73, 0x66, 0x06,
0xee, 0x04, 0xef, 0xe6, 0x3c, 0x7d, 0x57,
0x22, 0x7f, 0x1f, 0x62, 0x1c, 0x7e, 0x20,
0xda, 0x97, 0xd0, 0x27, 0x23, 0xf6, 0x77,
0x5b, 0x49, 0x97, 0xe1, 0x65, 0x91, 0x13,
0x93, 0xd6, 0x12, 0xc3, 0x66, 0x91, 0x76,
0xe8, 0x47, 0x4c, 0x6a, 0x1b, 0xa2, 0x02,
0xf8, 0x94, 0xaa, 0xe0, 0x1b, 0x0b, 0x17,
0x86, 0x5e, 0xf5, 0x17, 0x23, 0xf5, 0x17,
0x91, 0x6b, 0xd7, 0x2f, 0x5a, 0xfe, 0x8a,
0x63, 0x28, 0x31, 0x1e, 0x09, 0x60, 0x29,
0x5d, 0x55, 0xd8, 0x79, 0xeb, 0x78, 0x36,
0x44, 0x69, 0xa4, 0x76, 0xa5, 0x35, 0x30,
0xca, 0xc9, 0xf9, 0x62, 0xd7, 0x82, 0x13,
0x56, 0xd0, 0x58, 0xfe, 0x16, 0x4b, 0xfb,
0xa8, 0x4c, 0xb3, 0xd7, 0xcf, 0x5f, 0x93,
0x9d, 0xc4, 0x11, 0xb4, 0xdd, 0xf8, 0x8f,
0xe1, 0x11 ),
0 );
bigint_is_geq_ok ( BIGINT ( 0xd4, 0x6b, 0x0a, 0x2e, 0x9f, 0xde, 0x4b,
0x64, 0xfa, 0x6b, 0x37, 0x73, 0x66, 0x06,
0xee, 0x04, 0xef, 0xe6, 0x3c, 0x7d, 0x57,
0x22, 0x7f, 0x1f, 0x62, 0x1c, 0x7e, 0x20,
0xda, 0x97, 0xd0, 0x27, 0x23, 0xf6, 0x77,
0x5b, 0x49, 0x97, 0xe1, 0x65, 0x91, 0x13,
0x93, 0xd6, 0x12, 0xc3, 0x66, 0x91, 0x76,
0xe8, 0x47, 0x4c, 0x6a, 0x1b, 0xa2, 0x02,
0xf8, 0x94, 0xaa, 0xe0, 0x1b, 0x0b, 0x17,
0x86, 0x5e, 0xf5, 0x17, 0x23, 0xf5, 0x17,
0x91, 0x6b, 0xd7, 0x2f, 0x5a, 0xfe, 0x8a,
0x63, 0x28, 0x31, 0x1e, 0x09, 0x60, 0x29,
0x5d, 0x55, 0xd8, 0x79, 0xeb, 0x78, 0x36,
0x44, 0x69, 0xa4, 0x76, 0xa5, 0x35, 0x30,
0xca, 0xc9, 0xf9, 0x62, 0xd7, 0x82, 0x13,
0x56, 0xd0, 0x58, 0xfe, 0x16, 0x4b, 0xfb,
0xa8, 0x4c, 0xb3, 0xd7, 0xcf, 0x5f, 0x93,
0x9d, 0xc4, 0x11, 0xb4, 0xdd, 0xf8, 0x8f,
0xe1, 0x11 ),
BIGINT ( 0x2a, 0x98, 0xfd, 0x87, 0x5d, 0x9f, 0xb4,
0x8b, 0x5c, 0xcd, 0x5f, 0xcd, 0x53, 0xb3,
0xd1, 0x81, 0x6a, 0x9c, 0x93, 0x66, 0x40,
0xa7, 0x64, 0xe0, 0x8c, 0xec, 0x96, 0x63,
0x4d, 0x29, 0xfa, 0xb1, 0x5d, 0x93, 0x2f,
0xf9, 0x36, 0xea, 0x3b, 0xc1, 0xaf, 0x85,
0xcb, 0xde, 0x2d, 0xc8, 0x48, 0x33, 0xce,
0x7b, 0xa4, 0xa4, 0xda, 0x0f, 0xaa, 0x1b,
0xcb, 0xed, 0xbe, 0x3a, 0xa5, 0xbb, 0x73,
0x28, 0x04, 0xc6, 0x2a, 0xfb, 0x3a, 0xc3,
0xae, 0x42, 0x1f, 0x53, 0x6c, 0xb2, 0x76,
0xb7, 0xe2, 0x88, 0xcb, 0x88, 0xcf, 0xf0,
0x52, 0x81, 0xd3, 0xb2, 0x1f, 0x56, 0xe1,
0xe1, 0x47, 0x93, 0x6f, 0x2b, 0x49, 0xaa,
0x50, 0x99, 0x7a, 0xc4, 0x56, 0xb7, 0x13,
0x80, 0xf4, 0x73, 0x88, 0xc7, 0x39, 0x83,
0x67, 0xc7, 0xcc, 0xb2, 0x28, 0x7a, 0xd3,
0xdc, 0x48, 0xea, 0x62, 0x0d, 0xf5, 0x5a,
0x27, 0x96 ),
1 );
bigint_is_geq_ok ( BIGINT ( 0x2a, 0x98, 0xfd, 0x87, 0x5d, 0x9f, 0xb4,
0x8b, 0x5c, 0xcd, 0x5f, 0xcd, 0x53, 0xb3,
0xd1, 0x81, 0x6a, 0x9c, 0x93, 0x66, 0x40,
0xa7, 0x64, 0xe0, 0x8c, 0xec, 0x96, 0x63,
0x4d, 0x29, 0xfa, 0xb1, 0x5d, 0x93, 0x2f,
0xf9, 0x36, 0xea, 0x3b, 0xc1, 0xaf, 0x85,
0xcb, 0xde, 0x2d, 0xc8, 0x48, 0x33, 0xce,
0x7b, 0xa4, 0xa4, 0xda, 0x0f, 0xaa, 0x1b,
0xcb, 0xed, 0xbe, 0x3a, 0xa5, 0xbb, 0x73,
0x28, 0x04, 0xc6, 0x2a, 0xfb, 0x3a, 0xc3,
0xae, 0x42, 0x1f, 0x53, 0x6c, 0xb2, 0x76,
0xb7, 0xe2, 0x88, 0xcb, 0x88, 0xcf, 0xf0,
0x52, 0x81, 0xd3, 0xb2, 0x1f, 0x56, 0xe1,
0xe1, 0x47, 0x93, 0x6f, 0x2b, 0x49, 0xaa,
0x50, 0x99, 0x7a, 0xc4, 0x56, 0xb7, 0x13,
0x80, 0xf4, 0x73, 0x88, 0xc7, 0x39, 0x83,
0x67, 0xc7, 0xcc, 0xb2, 0x28, 0x7a, 0xd3,
0xdc, 0x48, 0xea, 0x62, 0x0d, 0xf5, 0x5a,
0x27, 0x96 ),
BIGINT ( 0x2a, 0x98, 0xfd, 0x87, 0x5d, 0x9f, 0xb4,
0x8b, 0x5c, 0xcd, 0x5f, 0xcd, 0x53, 0xb3,
0xd1, 0x81, 0x6a, 0x9c, 0x93, 0x66, 0x40,
0xa7, 0x64, 0xe0, 0x8c, 0xec, 0x96, 0x63,
0x4d, 0x29, 0xfa, 0xb1, 0x5d, 0x93, 0x2f,
0xf9, 0x36, 0xea, 0x3b, 0xc1, 0xaf, 0x85,
0xcb, 0xde, 0x2d, 0xc8, 0x48, 0x33, 0xce,
0x7b, 0xa4, 0xa4, 0xda, 0x0f, 0xaa, 0x1b,
0xcb, 0xed, 0xbe, 0x3a, 0xa5, 0xbb, 0x73,
0x28, 0x04, 0xc6, 0x2a, 0xfb, 0x3a, 0xc3,
0xae, 0x42, 0x1f, 0x53, 0x6c, 0xb2, 0x76,
0xb7, 0xe2, 0x88, 0xcb, 0x88, 0xcf, 0xf0,
0x52, 0x81, 0xd3, 0xb2, 0x1f, 0x56, 0xe1,
0xe1, 0x47, 0x93, 0x6f, 0x2b, 0x49, 0xaa,
0x50, 0x99, 0x7a, 0xc4, 0x56, 0xb7, 0x13,
0x80, 0xf4, 0x73, 0x88, 0xc7, 0x39, 0x83,
0x67, 0xc7, 0xcc, 0xb2, 0x28, 0x7a, 0xd3,
0xdc, 0x48, 0xea, 0x62, 0x0d, 0xf5, 0x5a,
0x27, 0x96 ),
1 );
bigint_bit_is_set_ok ( BIGINT ( 0x37 ),
0, 1 );
bigint_bit_is_set_ok ( BIGINT ( 0xe6, 0xcb ),
0, 1 );
bigint_bit_is_set_ok ( BIGINT ( 0xd9, 0x0c, 0x5b ),
0, 1 );
bigint_bit_is_set_ok ( BIGINT ( 0x8b, 0x56, 0x89, 0xaf ),
0, 1 );
bigint_bit_is_set_ok ( BIGINT ( 0x25, 0xfc, 0xaf, 0xeb, 0x81, 0xc3,
0xb8, 0x2f, 0xbb, 0xe3, 0x07, 0xb2,
0xe2, 0x2a, 0xe2, 0x2d, 0xb4, 0x4d,
0x6d, 0xec, 0x51, 0xa0, 0x2f ),
0, 1 );
bigint_bit_is_set_ok ( BIGINT ( 0x25, 0xfc, 0xaf, 0xeb, 0x81, 0xc3,
0xb8, 0x2f, 0xbb, 0xe3, 0x07, 0xb2,
0xe2, 0x2a, 0xe2, 0x2d, 0xb4, 0x4d,
0x6d, 0xec, 0x51, 0xa0, 0x2f ),
45, 0 );
bigint_bit_is_set_ok ( BIGINT ( 0x88, 0x04, 0xec, 0xe6, 0xfb, 0x31,
0x87, 0x43, 0xb2, 0x04, 0x9e, 0x09,
0xba, 0x3e, 0x6d, 0x64, 0x1a, 0x85,
0xb6, 0x46, 0x7d, 0x71, 0x3c, 0x06,
0xd6, 0x40, 0x52, 0x39, 0x95, 0xa1,
0x06, 0xff, 0x6a, 0x5c, 0xa3, 0x6d,
0x4a, 0xc9, 0x77, 0x87, 0x75, 0x25,
0x57, 0x65, 0x72, 0x73, 0x64, 0x7e,
0xe9, 0x16, 0x17, 0xf3, 0x65, 0x3f,
0xd5, 0xcc, 0xd7, 0xa2, 0xee, 0xe7,
0x8d, 0x48, 0xd5, 0x7e, 0xdd, 0x59,
0x4b, 0xf0, 0x96, 0x8b, 0x21, 0x65,
0x04, 0x66, 0xc5, 0xff, 0x3e, 0x60,
0xba, 0x28, 0x38, 0x7d, 0x9c, 0x09,
0xd1, 0x8e, 0xac, 0x73, 0x8e, 0xf2,
0x1e, 0xdf, 0x83, 0x6e, 0x54, 0xd5,
0x34, 0xc1, 0xc6, 0xf9, 0x62, 0x2a,
0x7d, 0xec, 0x47, 0xf2, 0xfc, 0xa2,
0x10, 0x0a, 0x67, 0x1b, 0xc6, 0x11,
0x9d, 0x68, 0x25, 0x8b, 0xb5, 0x9b,
0x83, 0xf8, 0xa2, 0x11, 0xf5, 0xd4,
0xcb, 0xe0 ),
0, 0 );
bigint_bit_is_set_ok ( BIGINT ( 0x88, 0x04, 0xec, 0xe6, 0xfb, 0x31,
0x87, 0x43, 0xb2, 0x04, 0x9e, 0x09,
0xba, 0x3e, 0x6d, 0x64, 0x1a, 0x85,
0xb6, 0x46, 0x7d, 0x71, 0x3c, 0x06,
0xd6, 0x40, 0x52, 0x39, 0x95, 0xa1,
0x06, 0xff, 0x6a, 0x5c, 0xa3, 0x6d,
0x4a, 0xc9, 0x77, 0x87, 0x75, 0x25,
0x57, 0x65, 0x72, 0x73, 0x64, 0x7e,
0xe9, 0x16, 0x17, 0xf3, 0x65, 0x3f,
0xd5, 0xcc, 0xd7, 0xa2, 0xee, 0xe7,
0x8d, 0x48, 0xd5, 0x7e, 0xdd, 0x59,
0x4b, 0xf0, 0x96, 0x8b, 0x21, 0x65,
0x04, 0x66, 0xc5, 0xff, 0x3e, 0x60,
0xba, 0x28, 0x38, 0x7d, 0x9c, 0x09,
0xd1, 0x8e, 0xac, 0x73, 0x8e, 0xf2,
0x1e, 0xdf, 0x83, 0x6e, 0x54, 0xd5,
0x34, 0xc1, 0xc6, 0xf9, 0x62, 0x2a,
0x7d, 0xec, 0x47, 0xf2, 0xfc, 0xa2,
0x10, 0x0a, 0x67, 0x1b, 0xc6, 0x11,
0x9d, 0x68, 0x25, 0x8b, 0xb5, 0x9b,
0x83, 0xf8, 0xa2, 0x11, 0xf5, 0xd4,
0xcb, 0xe0 ),
45, 1 );
bigint_bit_is_set_ok ( BIGINT ( 0x88, 0x04, 0xec, 0xe6, 0xfb, 0x31,
0x87, 0x43, 0xb2, 0x04, 0x9e, 0x09,
0xba, 0x3e, 0x6d, 0x64, 0x1a, 0x85,
0xb6, 0x46, 0x7d, 0x71, 0x3c, 0x06,
0xd6, 0x40, 0x52, 0x39, 0x95, 0xa1,
0x06, 0xff, 0x6a, 0x5c, 0xa3, 0x6d,
0x4a, 0xc9, 0x77, 0x87, 0x75, 0x25,
0x57, 0x65, 0x72, 0x73, 0x64, 0x7e,
0xe9, 0x16, 0x17, 0xf3, 0x65, 0x3f,
0xd5, 0xcc, 0xd7, 0xa2, 0xee, 0xe7,
0x8d, 0x48, 0xd5, 0x7e, 0xdd, 0x59,
0x4b, 0xf0, 0x96, 0x8b, 0x21, 0x65,
0x04, 0x66, 0xc5, 0xff, 0x3e, 0x60,
0xba, 0x28, 0x38, 0x7d, 0x9c, 0x09,
0xd1, 0x8e, 0xac, 0x73, 0x8e, 0xf2,
0x1e, 0xdf, 0x83, 0x6e, 0x54, 0xd5,
0x34, 0xc1, 0xc6, 0xf9, 0x62, 0x2a,
0x7d, 0xec, 0x47, 0xf2, 0xfc, 0xa2,
0x10, 0x0a, 0x67, 0x1b, 0xc6, 0x11,
0x9d, 0x68, 0x25, 0x8b, 0xb5, 0x9b,
0x83, 0xf8, 0xa2, 0x11, 0xf5, 0xd4,
0xcb, 0xe0 ),
1013, 0 );
bigint_max_set_bit_ok ( BIGINT ( 0x3a ),
6 );
bigint_max_set_bit_ok ( BIGINT ( 0x03 ),
2 );
bigint_max_set_bit_ok ( BIGINT ( 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0xff ),
8 );
bigint_max_set_bit_ok ( BIGINT ( 0x20, 0x30 ),
14 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x10 ),
5 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0xff, 0xff ),
16 );
bigint_max_set_bit_ok ( BIGINT ( 0x06, 0xdb, 0x7a ),
19 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0xff, 0xff, 0xff ),
24 );
bigint_max_set_bit_ok ( BIGINT ( 0xee, 0xcb, 0x7b, 0xfd ),
32 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x01, 0xdd ),
9 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff ),
32 );
bigint_max_set_bit_ok ( BIGINT ( 0x32, 0x39, 0x96, 0x52, 0x10, 0x67,
0x7e, 0x32, 0xfc, 0x4e, 0x56, 0xc3,
0x68, 0x18, 0x76, 0x1a, 0xac, 0x0e,
0x93, 0xee, 0x55, 0xc5, 0x6e ),
182 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0xc8, 0xe6, 0x59 ),
24 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff ),
184 );
bigint_max_set_bit_ok ( BIGINT ( 0xcd, 0xb3, 0x22, 0x30, 0xdd, 0xa7,
0xff, 0x37, 0xbf, 0xe3, 0x38, 0xf7,
0xe1, 0x41, 0x73, 0xea, 0x3a, 0xfc,
0x78, 0x9e, 0xfb, 0x4f, 0x85, 0xdc,
0x1c, 0x40, 0x89, 0x6e, 0xda, 0xf9,
0x9d, 0x6d, 0x12, 0x97, 0xb1, 0x80,
0x2a, 0xeb, 0x91, 0xce, 0x3b, 0x83,
0xb8, 0xa5, 0x3d, 0xce, 0x46, 0x56,
0xb7, 0xd1, 0x28, 0xbc, 0x93, 0x4e,
0x8c, 0x29, 0x6d, 0x2c, 0xcc, 0x58,
0x49, 0x2f, 0x37, 0xa0, 0x08, 0x37,
0x86, 0xdd, 0x38, 0x21, 0xa7, 0x57,
0x37, 0xe3, 0xc5, 0xcc, 0x50, 0x11,
0x1a, 0xe4, 0xea, 0xe7, 0x4d, 0x3c,
0x37, 0x65, 0x78, 0xd1, 0xf6, 0xc3,
0x94, 0x46, 0xd4, 0x0e, 0xd3, 0x9a,
0x21, 0x8b, 0xa6, 0x54, 0xc0, 0xd2,
0x88, 0x07, 0x24, 0xbf, 0x7d, 0x31,
0xfd, 0x15, 0xa8, 0x92, 0x65, 0xe1,
0x8d, 0xed, 0x70, 0x7b, 0x68, 0x0f,
0xcc, 0x13, 0xb9, 0xb2, 0xdd, 0x3c,
0x6a, 0x52 ),
1024 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x66, 0xd9,
0x91, 0x18, 0x6e, 0xd3, 0xff, 0x9b,
0xdf, 0xf1, 0x9c, 0x7b, 0xf0, 0xa0,
0xb9, 0xf5 ),
127 );
bigint_max_set_bit_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00 ),
0 );
bigint_max_set_bit_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff ),
1024 );
bigint_swap_ok ( BIGINT ( 0x68, 0x65, 0x6c, 0x6c, 0x6f ),
BIGINT ( 0x77, 0x6f, 0x72, 0x6c, 0x64 ) );
bigint_swap_ok ( BIGINT ( 0xc8, 0x1c, 0x31, 0xd7, 0x13, 0x69, 0x47,
0x32, 0xb0, 0x0a, 0xf7, 0x2d, 0xb9, 0xc3,
0x35, 0x96 ),
BIGINT ( 0x8b, 0x1d, 0x8f, 0x21, 0x76, 0x16, 0x4c,
0xf8, 0xb2, 0x63, 0xed, 0x89, 0x5e, 0x6b,
0x35, 0x7c ) );
bigint_multiply_ok ( BIGINT ( 0xf0 ),
BIGINT ( 0xeb ),
BIGINT ( 0xdc, 0x50 ) );
bigint_multiply_ok ( BIGINT ( 0xd7, 0x16 ),
BIGINT ( 0x88, 0xfb ),
BIGINT ( 0x73, 0x16, 0x92, 0x92 ) );
bigint_multiply_ok ( BIGINT ( 0xfe, 0xed, 0x1d ),
BIGINT ( 0x69, 0x9c, 0x03 ),
BIGINT ( 0x69, 0x2a, 0x9c, 0x5f, 0x73, 0x57 ) );
bigint_multiply_ok ( BIGINT ( 0x96, 0xe9, 0x6f, 0x81 ),
BIGINT ( 0x67, 0x3c, 0x5a, 0x16 ),
BIGINT ( 0x3c, 0xdb, 0x7f, 0xae, 0x12, 0x7e,
0xef, 0x16 ) );
bigint_multiply_ok ( BIGINT ( 0x39, 0x1f, 0xc8, 0x6a ),
BIGINT ( 0xba, 0x39, 0x4a, 0xb8, 0xac, 0xb3,
0x4f, 0x64, 0x28, 0x46, 0xa6, 0x99 ),
BIGINT ( 0x29, 0x8d, 0xe0, 0x5d, 0x08, 0xea,
0x0d, 0xc7, 0x82, 0x5d, 0xba, 0x96,
0x1c, 0xef, 0x83, 0x5a ) );
bigint_multiply_ok ( BIGINT ( 0xe8, 0x08, 0x0b, 0xe9, 0x29, 0x36,
0xea, 0x51, 0x1d, 0x75, 0x1a, 0xd5,
0xba, 0xc6, 0xa0, 0xf3, 0x48, 0x5c,
0xdf, 0x42, 0xdf, 0x28, 0x38 ),
BIGINT ( 0x22, 0x07, 0x41, 0x54, 0x4e, 0xf9,
0x90, 0xa8, 0xaf, 0xba, 0xf6, 0xb0,
0x35, 0x7e, 0x98, 0xef, 0x2c, 0x31,
0xc9, 0xa7, 0x25, 0x74, 0x8d ),
BIGINT ( 0x1e, 0xd7, 0xa5, 0x03, 0xc0, 0x18,
0x2e, 0x29, 0xb1, 0x3e, 0x96, 0x71,
0x90, 0xa5, 0x6d, 0x43, 0x58, 0xf7,
0x22, 0x80, 0x0b, 0x21, 0xc6, 0x70,
0x90, 0x1c, 0xa8, 0x85, 0x87, 0xaf,
0xd7, 0xdd, 0x27, 0x69, 0xaf, 0x20,
0xa0, 0x2d, 0x43, 0x5d, 0xda, 0xba,
0x4b, 0x3a, 0x86, 0xd8 ) );
bigint_multiply_ok ( BIGINT ( 0xa2, 0x0f, 0xc6, 0x08, 0x0a, 0x01,
0x19, 0x42, 0x0e, 0xaa, 0x5c, 0xae,
0x4f, 0x4e, 0xb0, 0xad, 0xb2, 0xe8,
0xee, 0xd5, 0x65, 0xec, 0x5a, 0xda,
0xc0, 0xba, 0x78, 0xa8, 0x0f, 0x15,
0x39, 0xd7, 0x7a, 0x10, 0xc2, 0xa7,
0xec, 0x44, 0xac, 0xad, 0x39, 0x04,
0x2e, 0x66, 0x54, 0x70, 0x57, 0xee,
0xf6, 0x97, 0x19, 0x71, 0x16, 0xf9,
0xbb, 0x2e, 0x84, 0x09, 0x6e, 0x9a,
0x3b, 0x16, 0xb2, 0x65, 0x74, 0x50,
0x19, 0xd1, 0xe9, 0x95, 0xa0, 0x7b,
0x33, 0xb5, 0xac, 0x7c, 0x9e, 0xd4,
0x68, 0x0d, 0xc9, 0xe4, 0x03, 0x86,
0x1a, 0xa3, 0x42, 0x33, 0x28, 0x14,
0x12, 0x7d, 0x5a, 0xd9, 0x30, 0x18,
0x0a, 0xf4, 0x0c, 0x96, 0x58, 0xc9,
0xb5, 0x37, 0xdb, 0x49, 0xdc, 0x01,
0x4a, 0xcb, 0x6d, 0x87, 0x52, 0xf6,
0xae, 0xa7, 0x71, 0x31, 0x9a, 0x1a,
0xe2, 0x1c, 0x87, 0x51, 0xc9, 0xeb,
0x70, 0x71 ),
BIGINT ( 0x7c, 0xdd, 0x2f, 0x5d, 0x27, 0xfe,
0xca, 0x70, 0x96, 0xc3, 0xb1, 0x1f,
0xac, 0xa9, 0x3a, 0xdc, 0xcd, 0xbc,
0x58, 0xb4, 0xde, 0xe7, 0xe5, 0x34,
0x1a, 0xc0, 0xb9, 0x46, 0xf7, 0x52,
0x76, 0x23, 0xe8, 0xe9, 0x92, 0xa1,
0x86, 0x3c, 0x6f, 0xf1, 0x22, 0xf4,
0x72, 0xb1, 0xde, 0xd3, 0x8f, 0x11,
0x9e, 0x52, 0xe5, 0x81, 0x54, 0xe9,
0xa7, 0x72, 0x3f, 0x3e, 0xa0, 0x80,
0xbb, 0xae, 0x0e, 0x30, 0x6a, 0x11,
0x91, 0x11, 0x3b, 0x3f, 0x44, 0x1f,
0x8d, 0x4d, 0xea, 0xdd, 0x09, 0x95,
0x9d, 0x02, 0xa6, 0x6d, 0x3b, 0x08,
0x40, 0x8d, 0xb4, 0x4b, 0x05, 0x74,
0x8c, 0x1f, 0xaa, 0x61, 0x6f, 0x0e,
0xcc, 0xcf, 0xe0, 0x81, 0x03, 0xe4,
0x9b, 0x11, 0xd9, 0xab, 0xf3, 0x24,
0xe2, 0x3b, 0xe0, 0x05, 0x60, 0x65,
0x16, 0xc6, 0x2e, 0x83, 0xa0, 0x98,
0x8e, 0x11, 0x05, 0x00, 0xe4, 0x3f,
0x7e, 0x65 ),
BIGINT ( 0x4f, 0x0b, 0xa9, 0x85, 0xb8, 0x31,
0x48, 0xea, 0x11, 0x44, 0xaf, 0x2d,
0xed, 0x1a, 0x76, 0x45, 0xac, 0x87,
0x0c, 0xf3, 0xd7, 0xc4, 0x8e, 0x5c,
0xd7, 0xdf, 0x28, 0x74, 0xa6, 0x40,
0xe4, 0x6b, 0x5b, 0x19, 0x36, 0x37,
0x9c, 0xcd, 0x43, 0x76, 0x15, 0x00,
0x5d, 0x23, 0xa2, 0x8a, 0x53, 0x25,
0xbf, 0x18, 0xda, 0xe6, 0x09, 0xdf,
0xaa, 0xeb, 0x9a, 0x82, 0x01, 0x14,
0x2b, 0x20, 0x2b, 0xb6, 0x22, 0x62,
0x6b, 0xcc, 0xd4, 0xc9, 0x02, 0x67,
0x95, 0x43, 0x75, 0x4e, 0x97, 0x4e,
0xec, 0x04, 0xde, 0x29, 0x0a, 0xef,
0xf7, 0xc1, 0x72, 0x8c, 0x64, 0x38,
0x16, 0x47, 0x9f, 0x16, 0x0c, 0xa5,
0x79, 0x6b, 0xea, 0x2e, 0x4c, 0x3d,
0x0c, 0xe6, 0x57, 0x51, 0x65, 0xa5,
0x3b, 0xca, 0xae, 0x54, 0x0c, 0x67,
0xf8, 0x23, 0x00, 0xc9, 0x8d, 0xe6,
0x16, 0x91, 0x19, 0xb3, 0x5b, 0x68,
0x7b, 0xf2, 0xe2, 0x5d, 0x69, 0x48,
0x3f, 0x2b, 0xa0, 0x4f, 0x7c, 0x3c,
0x26, 0xf9, 0xd9, 0xfd, 0x3d, 0x5d,
0xd6, 0x05, 0x00, 0xd8, 0xdf, 0x5a,
0x56, 0x8f, 0x16, 0x68, 0x4f, 0x15,
0x19, 0x9d, 0xd7, 0x11, 0x51, 0x7d,
0x73, 0x5c, 0xd4, 0xd5, 0xb4, 0xc7,
0x42, 0xe3, 0xee, 0xf1, 0x67, 0xd6,
0x69, 0x72, 0x04, 0x4b, 0x88, 0x3d,
0x05, 0xd8, 0x1e, 0x50, 0xcb, 0xce,
0x39, 0x19, 0x42, 0xb6, 0xa7, 0xf3,
0xba, 0x78, 0x90, 0xd2, 0x09, 0x05,
0x87, 0xf8, 0xc0, 0x9c, 0x47, 0xff,
0xbf, 0xaa, 0x21, 0x8d, 0x81, 0x86,
0xcd, 0x58, 0xdf, 0x30, 0xf1, 0xd1,
0x60, 0x53, 0x85, 0x40, 0xbf, 0x14,
0x3e, 0xdc, 0x9e, 0x9e, 0xc4, 0xc7,
0x48, 0xa0, 0x83, 0xe0, 0x99, 0x8b,
0x43, 0xf8, 0x52, 0x8a, 0x15, 0x88,
0x89, 0x83, 0x7d, 0x71, 0xbb, 0x62,
0x12, 0x7a, 0x23, 0x85, 0x3a, 0xbb,
0xdb, 0x09, 0xfa, 0x95 ) );
bigint_multiply_ok ( BIGINT ( 0xff ),
BIGINT ( 0xff ),
BIGINT ( 0xfe, 0x01 ) );
bigint_multiply_ok ( BIGINT ( 0xff, 0xff ),
BIGINT ( 0xff, 0xff ),
BIGINT ( 0xff, 0xfe, 0x00, 0x01 ) );
bigint_multiply_ok ( BIGINT ( 0xff, 0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xfe, 0x00, 0x00, 0x01 ) );
bigint_multiply_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00,
0x00, 0x01 ) );
bigint_multiply_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xfe, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x01 ) );
bigint_multiply_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xfe, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x01 ) );
bigint_reduce_ok ( BIGINT ( 0xaf ),
BIGINT ( 0x00 ),
BIGINT ( 0x00 ) );
bigint_reduce_ok ( BIGINT ( 0xab ),
BIGINT ( 0xab ),
BIGINT ( 0x00 ) );
bigint_reduce_ok ( BIGINT ( 0xcc, 0x9d, 0xa0, 0x79, 0x96, 0x6a, 0x46,
0xd5, 0xb4, 0x30, 0xd2, 0x2b, 0xbf ),
BIGINT ( 0x1d, 0x97, 0x63, 0xc9, 0x97, 0xcd, 0x43,
0xcb, 0x8e, 0x71, 0xac, 0x41, 0xdd ),
BIGINT ( 0x1d, 0x97, 0x63, 0xc9, 0x97, 0xcd, 0x43,
0xcb, 0x8e, 0x71, 0xac, 0x41, 0xdd ) );
bigint_reduce_ok ( BIGINT ( 0x21, 0xfa, 0x4f, 0xce, 0x0f, 0x0f, 0x4d,
0x43, 0xaa, 0xad, 0x21, 0x30, 0xe5 ),
BIGINT ( 0x21, 0xfa, 0x4f, 0xce, 0x0f, 0x0f, 0x4d,
0x43, 0xaa, 0xad, 0x21, 0x30, 0xe5 ),
BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ) );
bigint_reduce_ok ( BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0xf3, 0x65, 0x35, 0x41,
0x66, 0x65 ),
BIGINT ( 0xf9, 0x78, 0x96, 0x39, 0xee, 0x98, 0x42,
0x6a, 0xb8, 0x74, 0x0b, 0xe8, 0x5c, 0x76,
0x34, 0xaf ),
BIGINT ( 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0xb3, 0x07, 0xe8, 0xb7,
0x01, 0xf6 ) );
bigint_reduce_ok ( BIGINT ( 0x47, 0xaa, 0x88, 0x00, 0xd0, 0x30, 0x62,
0xfb, 0x5d, 0x55 ),
BIGINT ( 0xfe, 0x30, 0xe1, 0xc6, 0x65, 0x97, 0x48,
0x2e, 0x94, 0xd4 ),
BIGINT ( 0x27, 0x31, 0x49, 0xc3, 0xf5, 0x06, 0x1f,
0x3c, 0x7c, 0xd5 ) );
bigint_mod_invert_ok ( BIGINT ( 0x01 ), BIGINT ( 0x01 ) );
bigint_mod_invert_ok ( BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff ),
BIGINT ( 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff ) );
bigint_mod_invert_ok ( BIGINT ( 0xa4, 0xcb, 0xbc, 0xc9, 0x9f, 0x7a,
0x65, 0xbf ),
BIGINT ( 0xb9, 0xd5, 0xf4, 0x88, 0x0b, 0xf8,
0x8a, 0x3f ) );
bigint_mod_invert_ok ( BIGINT ( 0x95, 0x6a, 0xc5, 0xe7, 0x2e, 0x5b,
0x44, 0xed, 0xbf, 0x7e, 0xfe, 0x8d,
0xf4, 0x5a, 0x48, 0xc1 ),
BIGINT ( 0xad, 0xb8, 0x3d, 0x85, 0x10, 0xdf,
0xea, 0x70, 0x71, 0x2c, 0x80, 0xf4,
0x6e, 0x66, 0x47, 0x41 ) );
bigint_mod_invert_ok ( BIGINT ( 0x35, 0xe4, 0x80, 0x48, 0xdd, 0xa1,
0x46, 0xc0, 0x84, 0x63, 0xc1, 0xe4,
0xf7, 0xbf, 0xb3, 0x05 ),
BIGINT ( 0xf2, 0x9c, 0x63, 0x29, 0xfa, 0xe4,
0xbf, 0x90, 0xa6, 0x9a, 0xec, 0xcf,
0x5f, 0xe2, 0x21, 0xcd ) );
bigint_mod_invert_ok ( BIGINT ( 0xb9, 0xbb, 0x7f, 0x9c, 0x7a, 0x32,
0x43, 0xed, 0x9d, 0xd4, 0x0d, 0x6f,
0x32, 0xfa, 0x4b, 0x62, 0x38, 0x3a,
0xbf, 0x4c, 0xbd, 0xa8, 0x47, 0xce,
0xa2, 0x30, 0x34, 0xe0, 0x2c, 0x09,
0x14, 0x89 ),
BIGINT ( 0xfc, 0x05, 0xc4, 0x2a, 0x90, 0x99,
0x82, 0xf8, 0x81, 0x1d, 0x87, 0xb8,
0xca, 0xe4, 0x95, 0xe2, 0xac, 0x18,
0xb3, 0xe1, 0x3e, 0xc6, 0x5a, 0x03,
0x51, 0x6f, 0xb7, 0xe3, 0xa5, 0xd6,
0xa1, 0xb9 ) );
bigint_mod_invert_ok ( BIGINT ( 0xfe, 0x43, 0xf6, 0xa0, 0x32, 0x02,
0x47, 0xaa, 0xaa, 0x0e, 0x33, 0x19,
0x2e, 0xe6, 0x22, 0x07 ),
BIGINT ( 0x7b, 0xd1, 0x0f, 0x78, 0x0c, 0x65,
0xab, 0xb7 ) );
bigint_mod_multiply_ok ( BIGINT ( 0x37 ),
BIGINT ( 0x67 ),
BIGINT ( 0x3f ),
BIGINT ( 0x3a ) );
bigint_mod_multiply_ok ( BIGINT ( 0x45, 0x94 ),
BIGINT ( 0xbd, 0xd2 ),
BIGINT ( 0xca, 0xc7 ),
BIGINT ( 0xac, 0xc1 ) );
bigint_mod_multiply_ok ( BIGINT ( 0x8e, 0xcd, 0x74 ),
BIGINT ( 0xe2, 0xf1, 0xea ),
BIGINT ( 0x59, 0x51, 0x53 ),
BIGINT ( 0x22, 0xdd, 0x1c ) );
bigint_mod_multiply_ok ( BIGINT ( 0xc2, 0xa8, 0x40, 0x6f ),
BIGINT ( 0x29, 0xd7, 0xf4, 0x77 ),
BIGINT ( 0xbb, 0xbd, 0xdb, 0x3d ),
BIGINT ( 0x8f, 0x39, 0xd0, 0x47 ) );
bigint_mod_multiply_ok ( BIGINT ( 0x2e, 0xcb, 0x74, 0x7c, 0x64, 0x60,
0xb3, 0x44, 0xf3, 0x23, 0x49, 0x4a,
0xc6, 0xb6, 0xbf, 0xea, 0x80, 0xd8,
0x34, 0xc5, 0x54, 0x22, 0x09 ),
BIGINT ( 0x61, 0x2c, 0x5a, 0xc5, 0xde, 0x07,
0x65, 0x8e, 0xab, 0x88, 0x1a, 0x2e,
0x7a, 0x95, 0x17, 0xe3, 0x3b, 0x17,
0xe4, 0x21, 0xb0, 0xb4, 0x57 ),
BIGINT ( 0x8e, 0x46, 0xa5, 0x87, 0x7b, 0x7f,
0xc4, 0xd7, 0x31, 0xb1, 0x94, 0xe7,
0xe7, 0x1c, 0x7e, 0x7a, 0xc2, 0x6c,
0xce, 0xcb, 0xc8, 0x5d, 0x70 ),
BIGINT ( 0x1e, 0xd1, 0x5b, 0x3d, 0x1d, 0x17,
0x7c, 0x31, 0x95, 0x13, 0x1b, 0xd8,
0xee, 0x0a, 0xb0, 0xe1, 0x5b, 0x13,
0xad, 0x83, 0xe9, 0xf8, 0x7f ) );
bigint_mod_multiply_ok ( BIGINT ( 0x56, 0x37, 0xab, 0x07, 0x8b, 0x25,
0xa7, 0xc2, 0x50, 0x30, 0x43, 0xfc,
0x63, 0x8b, 0xdf, 0x84, 0x68, 0x85,
0xca, 0xce, 0x44, 0x5c, 0xb1, 0x14,
0xa4, 0xb5, 0xba, 0x43, 0xe0, 0x31,
0x45, 0x6b, 0x82, 0xa9, 0x0b, 0x9e,
0x3a, 0xb0, 0x39, 0x09, 0x2a, 0x68,
0x2e, 0x0f, 0x09, 0x54, 0x47, 0x04,
0xdb, 0xcf, 0x4a, 0x3a, 0x2d, 0x7b,
0x7d, 0x50, 0xa4, 0xc5, 0xeb, 0x13,
0xdd, 0x49, 0x61, 0x7d, 0x18, 0xa1,
0x0d, 0x6b, 0x58, 0xba, 0x9f, 0x7c,
0x81, 0x34, 0x9e, 0xf9, 0x9c, 0x9e,
0x28, 0xa8, 0x1c, 0x15, 0x16, 0x20,
0x3c, 0x0a, 0xb1, 0x11, 0x06, 0x93,
0xbc, 0xd8, 0x4e, 0x49, 0xae, 0x7b,
0xb4, 0x02, 0x8b, 0x1c, 0x5b, 0x18,
0xb4, 0xac, 0x7f, 0xdd, 0x70, 0xef,
0x87, 0xac, 0x1b, 0xac, 0x25, 0xa3,
0xc9, 0xa7, 0x3a, 0xc5, 0x76, 0x68,
0x09, 0x1f, 0xa1, 0x48, 0x53, 0xb6,
0x13, 0xac ),
BIGINT ( 0xef, 0x5c, 0x1f, 0x1a, 0x44, 0x64,
0x66, 0xcf, 0xdd, 0x3f, 0x0b, 0x27,
0x81, 0xa7, 0x91, 0x7a, 0x35, 0x7b,
0x0f, 0x46, 0x5e, 0xca, 0xbf, 0xf8,
0x50, 0x5e, 0x99, 0x7c, 0xc6, 0x64,
0x43, 0x00, 0x9f, 0xb2, 0xda, 0xfa,
0x42, 0x15, 0x9c, 0xa3, 0xd6, 0xc8,
0x64, 0xa7, 0x65, 0x4a, 0x98, 0xf7,
0xb3, 0x96, 0x5f, 0x42, 0xf9, 0x73,
0xe1, 0x75, 0xc3, 0xc4, 0x0b, 0x5d,
0x5f, 0xf3, 0x04, 0x8a, 0xee, 0x59,
0xa6, 0x1b, 0x06, 0x38, 0x0b, 0xa2,
0x9f, 0xb4, 0x4f, 0x6d, 0x50, 0x5e,
0x37, 0x37, 0x21, 0x83, 0x9d, 0xa3,
0x12, 0x16, 0x4d, 0xab, 0x36, 0x51,
0x21, 0xb1, 0x74, 0x66, 0x40, 0x9a,
0xd3, 0x72, 0xcc, 0x18, 0x40, 0x53,
0x89, 0xff, 0xd7, 0x00, 0x8d, 0x7e,
0x93, 0x81, 0xdb, 0x29, 0xb6, 0xd7,
0x23, 0x2b, 0x67, 0x2f, 0x11, 0x98,
0x49, 0x87, 0x2f, 0x46, 0xb7, 0x33,
0x6d, 0x12 ),
BIGINT ( 0x67, 0x7a, 0x17, 0x6a, 0xd2, 0xf8,
0x49, 0xfb, 0x7c, 0x95, 0x25, 0x54,
0xf0, 0xab, 0x5b, 0xb3, 0x0e, 0x01,
0xab, 0xd3, 0x65, 0x6f, 0x7e, 0x18,
0x05, 0xed, 0x9b, 0xc4, 0x90, 0x6c,
0xd0, 0x6d, 0x94, 0x79, 0x28, 0xd6,
0x24, 0x77, 0x9a, 0x08, 0xd2, 0x2f,
0x7c, 0x2d, 0xa0, 0x0c, 0x14, 0xbe,
0x7b, 0xee, 0x9e, 0x48, 0x88, 0x3c,
0x8f, 0x9f, 0xb9, 0x7a, 0xcb, 0x98,
0x76, 0x61, 0x0d, 0xee, 0xa2, 0x42,
0x67, 0x1b, 0x2c, 0x42, 0x8f, 0x41,
0xcc, 0x78, 0xba, 0xba, 0xaa, 0xa2,
0x92, 0xb0, 0x6e, 0x0c, 0x4e, 0xe1,
0xa5, 0x13, 0x7d, 0x8a, 0x8f, 0x81,
0x95, 0x8a, 0xdf, 0x57, 0x93, 0x88,
0x27, 0x4f, 0x1a, 0x59, 0xa4, 0x74,
0x22, 0xa9, 0x78, 0xe5, 0xed, 0xb1,
0x09, 0x26, 0x59, 0xde, 0x88, 0x21,
0x8d, 0xa2, 0xa8, 0x58, 0x10, 0x7b,
0x65, 0x96, 0xbf, 0x69, 0x3b, 0xc5,
0x55, 0xf8 ),
BIGINT ( 0x15, 0xf7, 0x00, 0xeb, 0xc7, 0x5a,
0x6f, 0xf0, 0x50, 0xf3, 0x21, 0x8a,
0x8e, 0xa6, 0xf6, 0x67, 0x56, 0x7d,
0x07, 0x45, 0x89, 0xdb, 0xd7, 0x7e,
0x9e, 0x28, 0x7f, 0xfb, 0xed, 0xca,
0x2c, 0xbf, 0x47, 0x77, 0x99, 0x95,
0xf3, 0xd6, 0x9d, 0xc5, 0x57, 0x81,
0x7f, 0x97, 0xf2, 0x6b, 0x24, 0xee,
0xce, 0xc5, 0x9b, 0xe6, 0x42, 0x2d,
0x37, 0xb7, 0xeb, 0x3d, 0xb5, 0xf7,
0x1e, 0x86, 0xc2, 0x40, 0x44, 0xc9,
0x85, 0x5a, 0x1a, 0xc0, 0xac, 0x9e,
0x78, 0x69, 0x00, 0x7b, 0x93, 0x65,
0xd7, 0x7f, 0x0c, 0xd6, 0xba, 0x4f,
0x06, 0x00, 0x61, 0x05, 0xb2, 0x44,
0xb4, 0xe7, 0xbb, 0x3b, 0x96, 0xb0,
0x6d, 0xe8, 0x43, 0xd2, 0x03, 0xb7,
0x0a, 0xc4, 0x6d, 0x30, 0xd8, 0xd5,
0xe6, 0x54, 0x65, 0xdd, 0xa9, 0x1b,
0x50, 0xc0, 0xb9, 0x95, 0xb0, 0x7d,
0x7c, 0xca, 0x63, 0xf8, 0x72, 0xbe,
0x3b, 0x00 ) );
bigint_mod_exp_ok ( BIGINT ( 0xcd ),
BIGINT ( 0xbb ),
BIGINT ( 0x25 ),
BIGINT ( 0xab ) );
bigint_mod_exp_ok ( BIGINT ( 0xc4 ),
BIGINT ( 0xe9 ),
BIGINT ( 0x02, 0x4c ),
BIGINT ( 0x7e ) );
bigint_mod_exp_ok ( BIGINT ( 0xcb ),
BIGINT ( 0xde ),
BIGINT ( 0xbd, 0x73, 0xbf ),
BIGINT ( 0x17 ) );
bigint_mod_exp_ok ( BIGINT ( 0x17 ),
BIGINT ( 0xb9 ),
BIGINT ( 0x39, 0x68, 0xba, 0x7d ),
BIGINT ( 0x17 ) );
bigint_mod_exp_ok ( BIGINT ( 0x2e ),
BIGINT ( 0xb7 ),
BIGINT ( 0x39, 0x07, 0x1b, 0x49, 0x5b, 0xea,
0xf2, 0x61, 0x75, 0x94, 0x60, 0x86,
0x73, 0xd0, 0xeb, 0x11, 0x08, 0x19,
0x90, 0x19, 0xe0, 0xed, 0x2a ),
BIGINT ( 0x19 ) );
bigint_mod_exp_ok ( BIGINT ( 0x59 ),
BIGINT ( 0xce ),
BIGINT ( 0xdf, 0xbc, 0x0d, 0x0c, 0x09, 0xeb,
0xf8, 0xcf, 0xdb, 0xb6, 0x00, 0xa3,
0x9e, 0xc3, 0x6c, 0x8d, 0xf1, 0xc3,
0x03, 0x36, 0xaa, 0xd4, 0x22, 0x7c,
0x20, 0x7b, 0xa9, 0x9a, 0x01, 0xe4,
0xf2, 0x50, 0x42, 0x29, 0x68, 0x7a,
0xa6, 0x2c, 0xdf, 0xb6, 0x51, 0xa9,
0x73, 0x10, 0x98, 0x37, 0x69, 0xb3,
0x21, 0x49, 0x6d, 0xcc, 0x80, 0xfa,
0x7e, 0x12, 0xe4, 0x9c, 0xc2, 0xbb,
0xe3, 0xa3, 0x10, 0x3f, 0xba, 0x99,
0x22, 0x79, 0x71, 0x39, 0x96, 0x7b,
0x1a, 0x89, 0xdc, 0xda, 0x43, 0x52,
0x50, 0x7b, 0xe3, 0x8c, 0xd3, 0xc0,
0xf5, 0x7d, 0xfc, 0x80, 0x71, 0x6e,
0xaf, 0x5c, 0xd0, 0x14, 0xc0, 0x60,
0x24, 0xa8, 0x9a, 0x8a, 0x54, 0x4a,
0x6f, 0x42, 0x7a, 0x14, 0x14, 0x25,
0xd5, 0x22, 0x08, 0x8f, 0xd9, 0xdb,
0xd4, 0x0f, 0x14, 0xf4, 0x3b, 0x26,
0x0e, 0xb6, 0x72, 0xd7, 0x03, 0xd5,
0xf0, 0x0e ),
BIGINT ( 0xa9 ) );
bigint_mod_exp_ok ( BIGINT ( 0x7f, 0x30 ),
BIGINT ( 0x73, 0x74 ),
BIGINT ( 0x75 ),
BIGINT ( 0x4b, 0xe8 ) );
bigint_mod_exp_ok ( BIGINT ( 0x04, 0x6c ),
BIGINT ( 0x99, 0x04 ),
BIGINT ( 0x33, 0xd2 ),
BIGINT ( 0x86, 0x74 ) );
bigint_mod_exp_ok ( BIGINT ( 0xca, 0x88 ),
BIGINT ( 0xdc, 0x60 ),
BIGINT ( 0x7e, 0x76, 0x79 ),
BIGINT ( 0x42, 0x40 ) );
bigint_mod_exp_ok ( BIGINT ( 0x68, 0x97 ),
BIGINT ( 0x52, 0x8b ),
BIGINT ( 0x4f, 0x7f, 0xe7, 0xda ),
BIGINT ( 0x22, 0x77 ) );
bigint_mod_exp_ok ( BIGINT ( 0xbd, 0x14 ),
BIGINT ( 0x9e, 0xfc ),
BIGINT ( 0x23, 0xf7, 0xd0, 0xa1, 0x9e, 0x9b,
0x05, 0xd2, 0x44, 0x24, 0x4f, 0x3f,
0x83, 0xcc, 0x49, 0x70, 0xa5, 0x0d,
0xfc, 0xa7, 0x43, 0xf3, 0x3e ),
BIGINT ( 0x1a, 0xc8 ) );
bigint_mod_exp_ok ( BIGINT ( 0x46, 0x3e ),
BIGINT ( 0xb8, 0xde ),
BIGINT ( 0xa9, 0xc0, 0xdc, 0x45, 0x65, 0x0d,
0xa5, 0x56, 0x70, 0x4c, 0xf1, 0xda,
0xab, 0x64, 0xc2, 0x04, 0xf6, 0x32,
0x20, 0x68, 0x31, 0x5f, 0x9a, 0x00,
0x0f, 0x7b, 0x24, 0x33, 0xdf, 0xaf,
0xfe, 0x03, 0x1e, 0x4a, 0xa1, 0xf8,
0x45, 0x8d, 0x5a, 0x7d, 0x12, 0x58,
0x00, 0x6d, 0xba, 0x79, 0x9f, 0xe1,
0xa1, 0xfc, 0x1f, 0xb9, 0xf3, 0xa7,
0x07, 0xf5, 0xfe, 0xd6, 0xa1, 0xba,
0xda, 0x63, 0xef, 0x39, 0x8e, 0xb7,
0x48, 0xa8, 0x81, 0x86, 0xb1, 0x22,
0x14, 0x9f, 0x9e, 0xac, 0x69, 0xf7,
0xae, 0x1f, 0xf2, 0x99, 0x41, 0xb7,
0x37, 0xa7, 0xbc, 0x42, 0xf2, 0x45,
0x43, 0xf2, 0x2a, 0xef, 0xc2, 0x83,
0xd5, 0x32, 0x6e, 0xfa, 0x49, 0x1c,
0x94, 0x9c, 0xc2, 0xc5, 0xad, 0x28,
0x53, 0x1c, 0x11, 0xc4, 0x1c, 0x78,
0x8f, 0x13, 0xdc, 0xb3, 0x2a, 0x63,
0xfd, 0x1f, 0x89, 0x9b, 0x0c, 0x31,
0x92, 0x73 ),
BIGINT ( 0x7b, 0x8a ) );
bigint_mod_exp_ok ( BIGINT ( 0xf3, 0xc3, 0xab ),
BIGINT ( 0xd0, 0x7e, 0xd0 ),
BIGINT ( 0xf6 ),
BIGINT ( 0x1f, 0xb3, 0x09 ) );
bigint_mod_exp_ok ( BIGINT ( 0x13, 0xec, 0xf6 ),
BIGINT ( 0x87, 0x1a, 0x9a ),
BIGINT ( 0x03, 0xf3 ),
BIGINT ( 0x15, 0xe9, 0x8e ) );
bigint_mod_exp_ok ( BIGINT ( 0x5a, 0x96, 0xe5 ),
BIGINT ( 0x56, 0x4a, 0xd1 ),
BIGINT ( 0x89, 0x62, 0x8e ),
BIGINT ( 0x34, 0xb8, 0xaa ) );
bigint_mod_exp_ok ( BIGINT ( 0x84, 0x7c, 0xbd ),
BIGINT ( 0x3c, 0x80, 0x0a ),
BIGINT ( 0x5e, 0x52, 0x9d, 0xba ),
BIGINT ( 0x04, 0xcb, 0x4f ) );
bigint_mod_exp_ok ( BIGINT ( 0x50, 0x01, 0x51 ),
BIGINT ( 0x02, 0xe6, 0x96 ),
BIGINT ( 0x34, 0x0c, 0x7e, 0xbf, 0x27, 0x23,
0x46, 0x92, 0x1c, 0xca, 0x91, 0xab,
0x50, 0x2c, 0x3a, 0x64, 0xc8, 0x4a,
0x75, 0xd6, 0xe2, 0xde, 0x31 ),
BIGINT ( 0x02, 0x16, 0x05 ) );
bigint_mod_exp_ok ( BIGINT ( 0x5e, 0x47, 0xd8 ),
BIGINT ( 0x26, 0xd1, 0xb6 ),
BIGINT ( 0x49, 0x61, 0x84, 0x7a, 0xa9, 0xfb,
0x93, 0x45, 0xe4, 0xfa, 0x53, 0x60,
0x73, 0x98, 0x5a, 0x17, 0xe7, 0x77,
0x2d, 0xcd, 0x97, 0xf4, 0xc0, 0x34,
0x46, 0xfa, 0xbd, 0x21, 0xdf, 0xa5,
0xa0, 0x12, 0x38, 0x7c, 0xbd, 0xd9,
0xcd, 0xbc, 0xde, 0x29, 0xa5, 0x13,
0xa8, 0xf0, 0xf6, 0x88, 0xc6, 0x31,
0xed, 0x90, 0x19, 0x11, 0x7d, 0xe1,
0x0e, 0x81, 0x98, 0x8e, 0x98, 0x86,
0xde, 0x2a, 0x4c, 0xad, 0xff, 0x57,
0x12, 0xbc, 0x4b, 0xaf, 0x21, 0xde,
0xca, 0x3a, 0x25, 0xd7, 0x98, 0xe3,
0x25, 0xbc, 0x17, 0x74, 0x0b, 0x9c,
0x53, 0xe1, 0x1a, 0xec, 0x9a, 0x5a,
0xdc, 0x68, 0xdf, 0xad, 0xd6, 0x71,
0x6b, 0x5b, 0x8b, 0x85, 0xbb, 0xe5,
0xd5, 0x14, 0x4c, 0x30, 0x27, 0x68,
0xd1, 0xf7, 0x58, 0x34, 0x4c, 0xe1,
0x71, 0xde, 0x7b, 0x8d, 0xa2, 0xe6,
0x0a, 0x44, 0x22, 0x26, 0x5a, 0x70,
0xbb, 0x68 ),
BIGINT ( 0x18, 0x36, 0x96 ) );
bigint_mod_exp_ok ( BIGINT ( 0xc7, 0x4a, 0xf0, 0x48 ),
BIGINT ( 0x5d, 0x27, 0x07, 0x54 ),
BIGINT ( 0x4a ),
BIGINT ( 0x48, 0x68, 0x7b, 0xe0 ) );
bigint_mod_exp_ok ( BIGINT ( 0xb4, 0x89, 0xc9, 0x5b ),
BIGINT ( 0x7c, 0xd7, 0xc7, 0xff ),
BIGINT ( 0xc6, 0x9c ),
BIGINT ( 0x0b, 0x2d, 0xf8, 0xf7 ) );
bigint_mod_exp_ok ( BIGINT ( 0xea, 0x72, 0x43, 0xfe ),
BIGINT ( 0xfc, 0x57, 0x2d, 0x47 ),
BIGINT ( 0x60, 0x01, 0x2c ),
BIGINT ( 0x12, 0x01, 0xe3, 0xf5 ) );
bigint_mod_exp_ok ( BIGINT ( 0x81, 0x7f, 0x27, 0x94 ),
BIGINT ( 0x17, 0x21, 0x67, 0xab ),
BIGINT ( 0x50, 0x19, 0x12, 0x52 ),
BIGINT ( 0x05, 0x17, 0x6b, 0x13 ) );
bigint_mod_exp_ok ( BIGINT ( 0x38, 0xab, 0xd4, 0xec ),
BIGINT ( 0x0c, 0x2a, 0x56, 0x38 ),
BIGINT ( 0x2f, 0x85, 0x85, 0x57, 0xf6, 0xde,
0x24, 0xb4, 0x28, 0x3c, 0x5a, 0x3c,
0x0b, 0x12, 0x85, 0x85, 0x85, 0x98,
0x46, 0x5b, 0x9c, 0x52, 0x3a ),
BIGINT ( 0x02, 0xe6, 0x6a, 0x70 ) );
bigint_mod_exp_ok ( BIGINT ( 0xa6, 0x35, 0xc0, 0x6f ),
BIGINT ( 0x23, 0xac, 0x78, 0x72 ),
BIGINT ( 0x6a, 0x07, 0x80, 0xbf, 0x1b, 0xa5,
0xf8, 0x0b, 0x90, 0x06, 0xa4, 0xa5,
0x44, 0x13, 0xba, 0x4b, 0xb3, 0xce,
0x9f, 0x55, 0x42, 0x56, 0xc3, 0x30,
0x82, 0x85, 0x5a, 0x3b, 0xae, 0x88,
0x92, 0x4e, 0x3c, 0x37, 0xf6, 0x80,
0x4c, 0x03, 0x3c, 0x1e, 0x2c, 0x17,
0xef, 0x9d, 0xd7, 0x6f, 0xdc, 0xbb,
0x42, 0x42, 0xa1, 0x7f, 0x97, 0x66,
0xcd, 0xc8, 0x8a, 0x7c, 0xc6, 0x70,
0x61, 0x54, 0x82, 0xd0, 0xd0, 0x8b,
0xd5, 0x4f, 0x57, 0x7b, 0x8e, 0xab,
0xdc, 0xbf, 0x8e, 0x85, 0x94, 0x83,
0x8a, 0xb3, 0x72, 0x69, 0x2d, 0x51,
0xdd, 0x86, 0x1e, 0x58, 0xb8, 0x00,
0xe2, 0x5e, 0xa7, 0xef, 0x6a, 0x6a,
0xb0, 0x10, 0x3d, 0x53, 0xfe, 0x23,
0x51, 0xc0, 0x51, 0xed, 0x1f, 0x02,
0x4b, 0x73, 0x17, 0x59, 0xfa, 0xb9,
0xa8, 0x05, 0xa7, 0x79, 0xc3, 0xc9,
0x4c, 0x2d, 0x58, 0x59, 0x10, 0x99,
0x71, 0xe6 ),
BIGINT ( 0x01, 0x63, 0xd0, 0x07 ) );
bigint_mod_exp_ok ( BIGINT ( 0xff, 0x2a, 0x37, 0x04, 0xd4, 0x08,
0x9f, 0xf5, 0xac, 0x29, 0x7f, 0x4b,
0x93, 0x86, 0x02, 0x26, 0xac, 0x29,
0xa8, 0xf9, 0x77, 0x91, 0x20 ),
BIGINT ( 0x2c, 0xb2, 0xe2, 0x1f, 0x4b, 0x97,
0xaa, 0x3b, 0xd1, 0x36, 0xb0, 0x40,
0x8b, 0x1c, 0x19, 0xa2, 0xea, 0xc8,
0xc6, 0x4e, 0x2a, 0x66, 0x50 ),
BIGINT ( 0x97 ),
BIGINT ( 0x04, 0x22, 0x44, 0xe2, 0x14, 0x54,
0x6c, 0x5a, 0xba, 0x1b, 0x39, 0xb7,
0xaa, 0x06, 0xcf, 0x2b, 0xc8, 0x7e,
0xc0, 0xe0, 0x70, 0xf2, 0x90 ) );
bigint_mod_exp_ok ( BIGINT ( 0xcd, 0xf3, 0xf7, 0x50, 0x13, 0x39,
0x13, 0x4a, 0x56, 0xc5, 0xb8, 0xa6,
0x42, 0x2d, 0x40, 0x5e, 0x07, 0xf2,
0x92, 0x2a, 0x51, 0x87, 0x20 ),
BIGINT ( 0x93, 0x1a, 0x28, 0xbb, 0x69, 0x4f,
0x31, 0x01, 0xe0, 0x88, 0x8a, 0x4c,
0x4f, 0x9b, 0xda, 0xf6, 0x4e, 0xf3,
0x11, 0xe7, 0x35, 0xa1, 0xfb ),
BIGINT ( 0x66, 0x69 ),
BIGINT ( 0x7a, 0x5a, 0x9b, 0x84, 0x72, 0x8f,
0x57, 0x31, 0xb4, 0x34, 0x70, 0x18,
0x77, 0xa6, 0x43, 0xa9, 0x51, 0x69,
0x07, 0x3e, 0xf6, 0x68, 0x82 ) );
bigint_mod_exp_ok ( BIGINT ( 0xdd, 0x4c, 0x85, 0xcb, 0x3f, 0x45,
0x61, 0xe0, 0x58, 0x1e, 0xad, 0xd3,
0x6b, 0xef, 0x82, 0x53, 0x4a, 0x16,
0x1a, 0xf0, 0x09, 0x82, 0x74 ),
BIGINT ( 0xd2, 0xa2, 0x73, 0x89, 0x0c, 0x56,
0xe4, 0x31, 0xdf, 0x70, 0x3c, 0x40,
0x0d, 0x36, 0xfc, 0x4a, 0xf3, 0xa2,
0x8f, 0x9a, 0x9d, 0xaa, 0xb0 ),
BIGINT ( 0xbc, 0xca, 0x45 ),
BIGINT ( 0x9f, 0x5f, 0x7c, 0xac, 0x5e, 0xc7,
0xf2, 0xc5, 0x72, 0x3d, 0xff, 0x29,
0xd2, 0x25, 0xa9, 0x64, 0x5b, 0xbe,
0x63, 0x63, 0xc6, 0x84, 0x20 ) );
bigint_mod_exp_ok ( BIGINT ( 0xf8, 0xc9, 0xb9, 0x3d, 0xe1, 0xff,
0xa6, 0x8e, 0xb0, 0xd2, 0xa9, 0xa9,
0xc1, 0x5c, 0xc5, 0x94, 0x90, 0xb9,
0xca, 0x2f, 0x1a, 0xbd, 0x21 ),
BIGINT ( 0xa7, 0xf4, 0xb0, 0x3c, 0xf4, 0x2b,
0x9d, 0x40, 0x5f, 0xfd, 0x2e, 0x28,
0xa9, 0x23, 0x01, 0xaf, 0x0b, 0x73,
0xaa, 0xcf, 0x14, 0xdc, 0xd8 ),
BIGINT ( 0x31, 0xe2, 0xe8, 0xf0 ),
BIGINT ( 0x53, 0x30, 0xc6, 0x10, 0x12, 0x7c,
0xb3, 0x91, 0x15, 0x5f, 0x01, 0x62,
0xec, 0x1f, 0x15, 0x61, 0x3b, 0x9a,
0x76, 0x22, 0xf8, 0x31, 0xb1 ) );
bigint_mod_exp_ok ( BIGINT ( 0xff, 0x8c, 0x04, 0x74, 0x3e, 0x93,
0xfd, 0xce, 0xd5, 0x7f, 0xc5, 0x58,
0xce, 0x00, 0x53, 0x44, 0x02, 0xf4,
0xfd, 0x01, 0xc3, 0xb0, 0x3c ),
BIGINT ( 0x2f, 0xbe, 0xb3, 0x2d, 0xd6, 0x59,
0x69, 0x44, 0xc0, 0xd4, 0x27, 0x9c,
0xff, 0x53, 0x9e, 0x66, 0x2c, 0x01,
0x3a, 0x96, 0x5d, 0x75, 0xc1 ),
BIGINT ( 0x47, 0x3e, 0xb2, 0x81, 0x51, 0x9a,
0xdf, 0x75, 0xba, 0xa5, 0x19, 0xc1,
0xc7, 0xcc, 0xae, 0x82, 0x9c, 0x3e,
0xfd, 0x7f, 0xb0, 0xd7, 0x00 ),
BIGINT ( 0x09, 0x9c, 0xd0, 0x49, 0x1d, 0x88,
0xd8, 0x08, 0x45, 0x61, 0x71, 0xa1,
0xb5, 0xab, 0xa9, 0x5b, 0xa8, 0xf1,
0xc6, 0x53, 0x68, 0x8f, 0x3e ) );
bigint_mod_exp_ok ( BIGINT ( 0xd8, 0x78, 0xad, 0x80, 0x81, 0xf1,
0x84, 0x23, 0x82, 0x5d, 0x49, 0x46,
0x75, 0xfd, 0xd1, 0x49, 0x53, 0x10,
0x4d, 0x10, 0xab, 0x0f, 0xf0 ),
BIGINT ( 0x78, 0x3d, 0x09, 0x1b, 0xea, 0xa4,
0xb9, 0x13, 0xf8, 0xb5, 0xb5, 0x5e,
0x69, 0xa4, 0xe1, 0xfd, 0x88, 0x58,
0x26, 0xb3, 0x76, 0xa2, 0x38 ),
BIGINT ( 0x3b, 0x12, 0xe0, 0x8e, 0xa2, 0x2f,
0x2a, 0x2b, 0xb1, 0x78, 0xf9, 0xf6,
0x93, 0x4d, 0x52, 0x82, 0x29, 0x2d,
0xe4, 0x36, 0x92, 0x49, 0xc1, 0x25,
0x6e, 0x26, 0xe6, 0x6e, 0xc2, 0x4d,
0xea, 0x13, 0x86, 0x85, 0x71, 0x4d,
0x85, 0x70, 0xf9, 0x2b, 0xa0, 0x0f,
0x96, 0xe5, 0x63, 0x7a, 0xb4, 0x25,
0x53, 0x1a, 0xd8, 0x30, 0x36, 0xba,
0x6e, 0x2e, 0xce, 0x2d, 0x8f, 0x32,
0xe9, 0xdc, 0x91, 0x9e, 0xd4, 0xf1,
0x3b, 0x40, 0xc9, 0xf4, 0x97, 0x74,
0x5e, 0x69, 0xcd, 0x34, 0x4a, 0x18,
0x65, 0xe5, 0x07, 0xb5, 0x9e, 0x2a,
0xc4, 0xeb, 0xb6, 0x96, 0x7b, 0x99,
0x0c, 0xe4, 0xb3, 0x85, 0xff, 0x17,
0x72, 0x5d, 0xf6, 0x30, 0xb4, 0xff,
0x98, 0xe6, 0xf6, 0x31, 0x24, 0x82,
0x91, 0xa6, 0x18, 0x6d, 0x0b, 0x84,
0x6f, 0x5f, 0x64, 0xa3, 0xdf, 0x92,
0x06, 0x16, 0xe3, 0x7c, 0x08, 0x61,
0x77, 0xce ),
BIGINT ( 0x17, 0xc9, 0xc5, 0x38, 0x4c, 0x15,
0x0f, 0x4e, 0xc2, 0x90, 0x3b, 0x46,
0x7b, 0x2f, 0x95, 0x82, 0xfe, 0x51,
0x95, 0x2b, 0xff, 0xd5, 0x28 ) );
bigint_mod_exp_ok ( BIGINT ( 0x69, 0xa3, 0x7e, 0x24, 0xdf, 0x9e,
0x0b, 0x3e, 0x3f, 0x43, 0x06, 0x0e,
0x1d, 0x57, 0x74, 0xe0, 0xa0, 0x5b,
0x82, 0xca, 0xb0, 0x33, 0x8b, 0xe4,
0x39, 0x27, 0x41, 0xd4, 0x2e, 0x30,
0x3a, 0x0e, 0x62, 0x6f, 0xfa, 0xb4,
0x02, 0x88, 0x70, 0x35, 0xa6, 0xea,
0x7d, 0xb2, 0x87, 0xc3, 0xa5, 0x50,
0x49, 0x38, 0xa4, 0x68, 0xa9, 0xe4,
0xa6, 0xcc, 0xd7, 0x13, 0xb1, 0xd9,
0x1c, 0x6a, 0x9a, 0xb8, 0x6c, 0x9b,
0xff, 0xcd, 0x2c, 0xb3, 0xbd, 0xe2,
0xfd, 0x1f, 0x08, 0xdd, 0xc6, 0xee,
0x18, 0x0c, 0xa5, 0xcd, 0x09, 0x19,
0x51, 0x51, 0xa5, 0x6f, 0x93, 0x1b,
0x34, 0xfd, 0x8f, 0xd9, 0x87, 0xed,
0x15, 0x7e, 0x36, 0x60, 0xdd, 0x1b,
0xf4, 0xcc, 0xc4, 0x4c, 0x19, 0x2b,
0xd6, 0x1e, 0xec, 0x51, 0xe9, 0x27,
0xe9, 0xbd, 0x6a, 0x3f, 0x91, 0x45,
0xc3, 0x6d, 0x40, 0x7e, 0x6c, 0x56,
0x05, 0x5a ),
BIGINT ( 0x5c, 0x96, 0x05, 0x81, 0x94, 0x45,
0xcf, 0x47, 0x5f, 0x1b, 0xb0, 0xf9,
0xef, 0x13, 0x8f, 0xcc, 0x71, 0xfd,
0x50, 0xf1, 0xe7, 0x62, 0x6e, 0xfa,
0x48, 0x66, 0x1c, 0xf7, 0xef, 0x09,
0x12, 0xa2, 0xfd, 0x17, 0xb7, 0x6a,
0x3b, 0xed, 0xf7, 0x86, 0xd2, 0xbe,
0x95, 0x90, 0xc6, 0x00, 0x14, 0x8d,
0xe3, 0x27, 0xbe, 0x03, 0x7c, 0x9e,
0x6b, 0x51, 0x31, 0x8d, 0x18, 0xc4,
0x16, 0xd2, 0x84, 0x63, 0x9b, 0xe9,
0xa4, 0xf8, 0xff, 0x70, 0x4d, 0xeb,
0x6f, 0x4a, 0xb7, 0x5b, 0x54, 0xf1,
0xb5, 0xbe, 0x78, 0xb6, 0xfd, 0x8b,
0xe1, 0x39, 0x62, 0x85, 0x9b, 0xde,
0x30, 0xa8, 0xe4, 0x37, 0x52, 0x57,
0x39, 0x79, 0xdb, 0x0b, 0x19, 0x6b,
0xc9, 0x17, 0xfd, 0x8c, 0x2c, 0xaa,
0xa4, 0xf1, 0x04, 0xd1, 0xd3, 0x2f,
0xbb, 0x3a, 0x36, 0x82, 0x31, 0xa4,
0x40, 0xd4, 0x87, 0x46, 0xe3, 0x6e,
0xd0, 0x17 ),
BIGINT ( 0x93 ),
BIGINT ( 0x0d, 0x39, 0x92, 0x57, 0xaa, 0x6d,
0xfc, 0x3b, 0x10, 0x18, 0x6d, 0x59,
0xbe, 0x31, 0x8f, 0xee, 0xf9, 0x82,
0x84, 0xe0, 0xdf, 0xa5, 0x00, 0x28,
0xd1, 0x64, 0x6b, 0x4b, 0x43, 0x3b,
0x76, 0x3e, 0x6b, 0xc4, 0xe4, 0xf5,
0x0b, 0x59, 0x5a, 0xe4, 0x53, 0x5e,
0x02, 0xd4, 0xde, 0x72, 0xd3, 0xa3,
0x58, 0x66, 0xa7, 0xdd, 0x2b, 0x0b,
0xa4, 0x83, 0xd0, 0xd9, 0xef, 0x29,
0x3d, 0x2f, 0x97, 0xff, 0x9a, 0xc7,
0xf6, 0x8a, 0x8d, 0x59, 0xef, 0x87,
0xd1, 0xe6, 0xba, 0x4d, 0x99, 0xd9,
0x5f, 0x5e, 0x7a, 0x7e, 0x67, 0x22,
0x5b, 0x77, 0x83, 0xa2, 0x02, 0xfd,
0xb2, 0xe4, 0xf6, 0x20, 0x4c, 0x12,
0x20, 0xa7, 0xda, 0x5b, 0x3b, 0x8c,
0xa2, 0xca, 0xda, 0x20, 0xaa, 0x27,
0xe6, 0x54, 0x3e, 0xa8, 0x6f, 0x64,
0x9d, 0xa7, 0x0d, 0x57, 0x1b, 0x21,
0xff, 0xd2, 0xe2, 0xb2, 0x0a, 0x4f,
0xb7, 0x0e ) );
bigint_mod_exp_ok ( BIGINT ( 0x06, 0xcf, 0x54, 0xf2, 0x0d, 0x62,
0x33, 0xdd, 0xe7, 0x4d, 0x7f, 0x2f,
0x8e, 0x52, 0x73, 0xf4, 0x73, 0x68,
0x4b, 0x13, 0x6e, 0x58, 0x6b, 0x4a,
0xb8, 0x4c, 0xef, 0x73, 0xfe, 0x5f,
0xf6, 0xd0, 0xbb, 0x82, 0x17, 0x3f,
0x9d, 0x91, 0xf8, 0xa3, 0xb8, 0x79,
0xef, 0x41, 0x38, 0xc1, 0xef, 0xc9,
0xc6, 0xcf, 0x2a, 0xc3, 0xaa, 0x75,
0x17, 0xda, 0xbc, 0x76, 0x29, 0x61,
0x6d, 0x05, 0x79, 0x0b, 0x44, 0xb1,
0x54, 0x75, 0xb7, 0xd9, 0xf6, 0xa8,
0xbd, 0xf7, 0x85, 0xe0, 0xe7, 0x90,
0x62, 0xce, 0x79, 0xfb, 0xc5, 0x23,
0xa5, 0x09, 0xc0, 0xc4, 0x4d, 0xe7,
0x9c, 0x49, 0x8f, 0x82, 0xf1, 0x31,
0x34, 0x85, 0xdd, 0x3b, 0xbe, 0xe9,
0x93, 0x19, 0x03, 0x75, 0x3f, 0xc4,
0xa4, 0x0f, 0x52, 0x53, 0xc1, 0xcd,
0x08, 0xb0, 0x05, 0x0c, 0xa2, 0x0c,
0x3a, 0x72, 0xb2, 0x3c, 0xdb, 0x4f,
0xac, 0xc6 ),
BIGINT ( 0xe4, 0x40, 0xd8, 0x30, 0x00, 0xcf,
0x4c, 0xfd, 0xda, 0xae, 0x90, 0xd3,
0x5b, 0xc7, 0x20, 0xcc, 0x2b, 0xe2,
0x0a, 0x39, 0x1e, 0xde, 0xef, 0x98,
0x16, 0x3b, 0x9d, 0x36, 0x63, 0x0d,
0x46, 0xed, 0x23, 0x6e, 0x38, 0xa8,
0x15, 0xb5, 0xb1, 0xaf, 0x47, 0xb1,
0xec, 0xaa, 0x8b, 0x57, 0xd6, 0xca,
0x39, 0x2f, 0x62, 0xbd, 0xd5, 0xf8,
0x98, 0x98, 0x5d, 0xfe, 0x14, 0xd6,
0xdc, 0xe5, 0x98, 0x60, 0x5b, 0x16,
0x92, 0xcb, 0xed, 0xb6, 0x9c, 0x5c,
0x82, 0x40, 0x6b, 0xaa, 0x48, 0x7a,
0xd4, 0xfe, 0xa3, 0xe7, 0x30, 0xf1,
0x7c, 0xfb, 0x94, 0x2e, 0xeb, 0xb6,
0x71, 0xe4, 0x33, 0x63, 0xc3, 0xb0,
0x94, 0x6d, 0xee, 0xa5, 0x15, 0x3f,
0x28, 0xf1, 0xfa, 0xdc, 0xf2, 0x13,
0x0f, 0xc7, 0xd9, 0xe0, 0xbf, 0x1b,
0x49, 0xee, 0x21, 0x8e, 0x26, 0xc9,
0x28, 0x21, 0x86, 0x1d, 0x46, 0x33,
0xd4, 0x69 ),
BIGINT ( 0xd9, 0x87 ),
BIGINT ( 0xdf, 0xff, 0xcc, 0xb7, 0xfe, 0x19,
0x02, 0x92, 0x9d, 0xab, 0x33, 0xd2,
0x21, 0xbc, 0xd3, 0xc4, 0x31, 0xad,
0x4b, 0xb3, 0x16, 0x50, 0x96, 0xd9,
0xdc, 0x88, 0x74, 0x60, 0xde, 0xdf,
0xb7, 0x83, 0xdb, 0x22, 0xef, 0xcb,
0xcb, 0xdb, 0x4c, 0xfb, 0x94, 0x4c,
0x3f, 0xf5, 0xf5, 0x99, 0x85, 0x21,
0x1a, 0x2b, 0xec, 0x90, 0x2d, 0xb4,
0x20, 0x3c, 0x27, 0x9f, 0xe5, 0xb1,
0x5c, 0x92, 0xfa, 0xb0, 0xa9, 0x8e,
0x2c, 0x21, 0x8e, 0x8d, 0xe5, 0x55,
0x84, 0x02, 0xa5, 0x15, 0x5c, 0x53,
0x1f, 0x40, 0x81, 0x0a, 0x10, 0xde,
0x21, 0x41, 0xa9, 0x97, 0xf8, 0x6f,
0xbf, 0x42, 0x58, 0x9e, 0xc6, 0xdd,
0x10, 0x33, 0x3f, 0xad, 0xe6, 0x8e,
0x57, 0x27, 0x37, 0x20, 0xa4, 0x86,
0xef, 0x39, 0x7b, 0x6f, 0x78, 0x77,
0xab, 0xa0, 0x62, 0xe1, 0xfd, 0x9c,
0xbe, 0xfa, 0x98, 0x2e, 0x29, 0xe3,
0xeb, 0x52 ) );
bigint_mod_exp_ok ( BIGINT ( 0x00, 0x91, 0xb3, 0x87, 0xe6, 0x01,
0x57, 0xe9, 0x68, 0xa4, 0xf4, 0x9b,
0xea, 0x6a, 0x8a, 0x9e, 0x1a, 0x8b,
0xd3, 0x85, 0x9d, 0xba, 0x85, 0xab,
0xd8, 0xcd, 0x25, 0x56, 0x8e, 0x85,
0x8a, 0x8e, 0x48, 0x9e, 0xb4, 0x90,
0xc8, 0x2e, 0x07, 0x78, 0x80, 0x49,
0xa0, 0xb7, 0x95, 0x6a, 0xd8, 0xad,
0xb5, 0xda, 0x5d, 0xe6, 0x11, 0x87,
0xb8, 0x33, 0x8f, 0xa8, 0x6f, 0x4e,
0xc6, 0xc3, 0x0d, 0xf5, 0xa9, 0x4e,
0xb2, 0x42, 0x53, 0x81, 0xcd, 0x33,
0x83, 0x49, 0xab, 0x0d, 0x0e, 0xf5,
0x2c, 0xcd, 0x84, 0x58, 0xf3, 0x30,
0xa3, 0x6e, 0x3c, 0x3a, 0xc6, 0x77,
0x43, 0xb0, 0xe7, 0x4b, 0x66, 0x30,
0xe9, 0x48, 0x0b, 0x0d, 0x86, 0x3f,
0xd8, 0xe2, 0xb5, 0x88, 0xc1, 0x44,
0xb2, 0x6b, 0xb0, 0x7a, 0x35, 0x3b,
0x56, 0x83, 0xb1, 0xac, 0x9e, 0xeb,
0x9b, 0x08, 0x43, 0xac, 0x0a, 0x3a,
0x31, 0x69 ),
BIGINT ( 0x96, 0x6f, 0xb0, 0xa7, 0x02, 0xb5,
0xd9, 0x19, 0xbe, 0x4b, 0x27, 0x65,
0x5b, 0x96, 0xd4, 0x0b, 0x49, 0x70,
0xf0, 0x09, 0x8e, 0xf2, 0x04, 0x85,
0x93, 0xe9, 0x2e, 0x09, 0x31, 0x76,
0x8b, 0xbb, 0xe9, 0xe1, 0x2b, 0x4f,
0xed, 0x83, 0xa6, 0x87, 0xa3, 0x07,
0x0a, 0x3d, 0x1c, 0x65, 0x14, 0x5a,
0xd5, 0xc0, 0x5d, 0x3c, 0x31, 0x9a,
0x83, 0xad, 0xca, 0x6a, 0x93, 0x0d,
0x1a, 0x67, 0x4e, 0x68, 0x06, 0x64,
0x53, 0x2e, 0x15, 0xd9, 0xdd, 0x5e,
0xcb, 0xb7, 0x2e, 0xef, 0xd3, 0xbb,
0x5f, 0xaf, 0xef, 0x9e, 0xf2, 0x7b,
0x69, 0x15, 0xb0, 0x18, 0x6c, 0x67,
0x10, 0xda, 0x33, 0x07, 0x48, 0x97,
0x31, 0xb3, 0x3d, 0x3d, 0xc9, 0x2e,
0x0b, 0x68, 0x91, 0x3f, 0x6a, 0x3b,
0x1a, 0xdf, 0xa8, 0x69, 0x46, 0x1c,
0xb2, 0x69, 0x08, 0x0b, 0x02, 0x1b,
0x03, 0x64, 0xae, 0xb6, 0x2d, 0xc6,
0xc4, 0x0a ),
BIGINT ( 0x6d, 0x3f, 0xdd ),
BIGINT ( 0x40, 0x6e, 0x9d, 0x3e, 0xeb, 0xa4,
0xb1, 0x8d, 0xb7, 0xb4, 0x0f, 0x5b,
0x12, 0xad, 0x27, 0x9e, 0xbd, 0xe7,
0xe5, 0x9d, 0xec, 0xb4, 0xac, 0x23,
0x5f, 0xa9, 0xec, 0x9c, 0xd1, 0x6a,
0xbe, 0x99, 0xba, 0xb3, 0x66, 0x0e,
0x17, 0xaa, 0x13, 0xa2, 0x2e, 0x01,
0x28, 0xb1, 0x6c, 0xba, 0xad, 0x68,
0x48, 0xf0, 0xf3, 0x4c, 0x08, 0x9f,
0xd1, 0x9c, 0xb7, 0x75, 0xc5, 0xb6,
0x5a, 0x05, 0xb0, 0x14, 0xd4, 0x61,
0xea, 0x18, 0x9f, 0xe6, 0xe5, 0xe3,
0xd4, 0xff, 0x35, 0x43, 0x0b, 0xb8,
0xf6, 0xe9, 0x19, 0x7a, 0x88, 0xa7,
0x4d, 0x01, 0x92, 0x05, 0xd2, 0x6e,
0xa3, 0xc1, 0xb6, 0x66, 0x75, 0xb1,
0x00, 0x0d, 0x42, 0x37, 0xcc, 0xca,
0xc0, 0x8d, 0xc8, 0x7e, 0x5c, 0xc9,
0x53, 0x81, 0x2f, 0xc4, 0x61, 0xb6,
0x96, 0x3b, 0xa5, 0x04, 0x14, 0x1b,
0xa7, 0x77, 0xa1, 0xbc, 0x73, 0x1d,
0xad, 0xed ) );
bigint_mod_exp_ok ( BIGINT ( 0x45, 0xfb, 0xf3, 0xdc, 0x31, 0xe5,
0x56, 0x7a, 0xee, 0x15, 0xfb, 0x16,
0xee, 0x6e, 0x90, 0x3e, 0xa3, 0x89,
0xc2, 0x6d, 0x9b, 0x06, 0x65, 0xd0,
0xcd, 0xa2, 0xcc, 0x01, 0x60, 0x0d,
0xd1, 0xdd, 0x68, 0x14, 0xc2, 0xcd,
0xd8, 0x79, 0x75, 0xad, 0x0a, 0x9f,
0x39, 0x5f, 0x52, 0x4b, 0x58, 0x31,
0x48, 0xbb, 0x2a, 0xcc, 0xe0, 0x42,
0x18, 0x32, 0xdc, 0x63, 0x14, 0x11,
0x4e, 0xab, 0x96, 0x29, 0xc5, 0x06,
0x79, 0xe5, 0x06, 0xf7, 0x59, 0xdb,
0x1e, 0x51, 0xfd, 0xc4, 0x48, 0x3a,
0x4c, 0x7f, 0xd0, 0xe2, 0x36, 0x86,
0xc1, 0x8b, 0xc5, 0x86, 0x52, 0xe0,
0xdb, 0x92, 0x5f, 0x0e, 0x19, 0xb1,
0xa3, 0x23, 0xdd, 0xf0, 0x78, 0xcc,
0x81, 0x3f, 0x4a, 0xe6, 0xb0, 0x32,
0xd1, 0x5c, 0x5e, 0x3a, 0xb0, 0xd8,
0xe2, 0x04, 0xc0, 0x30, 0x85, 0x1d,
0x5e, 0x28, 0xee, 0xd9, 0xb3, 0x83,
0x9f, 0xe2 ),
BIGINT ( 0xb3, 0x2c, 0x2e, 0xc5, 0xba, 0xf8,
0x41, 0x98, 0x79, 0x7e, 0xaa, 0x0c,
0x2a, 0x8f, 0xd9, 0x56, 0x55, 0xaa,
0x74, 0x60, 0x74, 0xd1, 0x49, 0x2c,
0x6f, 0x0a, 0x4e, 0xf8, 0x3f, 0x1b,
0x73, 0x4c, 0xe0, 0x17, 0x37, 0x06,
0x76, 0x73, 0xd5, 0x2d, 0x4d, 0x3f,
0xb0, 0x15, 0x7e, 0x98, 0xd0, 0xdf,
0xf0, 0x33, 0x78, 0xe2, 0xe6, 0xec,
0x21, 0x22, 0xad, 0xd5, 0xab, 0x2d,
0x0d, 0x59, 0x95, 0x05, 0x34, 0x1f,
0x51, 0xf5, 0xec, 0x93, 0x05, 0x15,
0x37, 0xcf, 0x93, 0x03, 0xd7, 0xf6,
0x35, 0x23, 0x8f, 0x33, 0xf6, 0xba,
0x42, 0xc8, 0x52, 0x94, 0xd3, 0x33,
0x3e, 0x39, 0x01, 0xd1, 0x55, 0x3f,
0x48, 0x84, 0xe9, 0xbc, 0x0b, 0x0f,
0xc9, 0x69, 0x41, 0x2c, 0x5f, 0x34,
0xd0, 0xe6, 0x15, 0x50, 0x06, 0x64,
0x5b, 0x8b, 0x71, 0x22, 0xb3, 0x3e,
0x09, 0x9c, 0x76, 0x13, 0x9b, 0x29,
0x57, 0x94 ),
BIGINT ( 0xca, 0x94, 0xf7, 0xca ),
BIGINT ( 0x83, 0x68, 0xb9, 0xe7, 0x91, 0xf3,
0x3b, 0x5a, 0x0b, 0xb6, 0x1e, 0x2f,
0x3f, 0x5f, 0xdc, 0x96, 0x5b, 0x7f,
0x8d, 0xc5, 0x8e, 0xda, 0x6e, 0x21,
0xe3, 0x20, 0xea, 0x37, 0x39, 0x3b,
0xb4, 0xd7, 0xf6, 0xba, 0x61, 0xfe,
0xdc, 0x7e, 0x82, 0x9a, 0x38, 0x7b,
0xd5, 0xb1, 0x11, 0x98, 0xc4, 0x88,
0x0b, 0x01, 0x7d, 0x81, 0xc9, 0x64,
0x23, 0xc3, 0x3e, 0xf3, 0x67, 0x95,
0x78, 0xca, 0xda, 0x52, 0xaf, 0x72,
0x25, 0xd9, 0xf0, 0x27, 0xd3, 0x1c,
0xfb, 0xad, 0xa1, 0xa7, 0x06, 0x2f,
0xaa, 0x2f, 0x86, 0x5c, 0x8b, 0x30,
0xe1, 0xda, 0x5a, 0x36, 0xf9, 0xfd,
0xbf, 0xfe, 0x0d, 0x03, 0xf8, 0x9c,
0x6b, 0x9b, 0xe5, 0x70, 0x6d, 0x75,
0xd7, 0x54, 0x28, 0x43, 0x34, 0x69,
0x98, 0x11, 0x29, 0xee, 0x50, 0x06,
0xa4, 0xc4, 0x11, 0x6d, 0x60, 0x8c,
0xcd, 0xd1, 0x88, 0xe9, 0x6b, 0xbb,
0xc1, 0xd4 ) );
bigint_mod_exp_ok ( BIGINT ( 0xa1, 0x01, 0x7e, 0xb4, 0x0e, 0x66,
0xa5, 0x07, 0x8b, 0x10, 0x84, 0x0d,
0x30, 0x0a, 0xa4, 0x2d, 0x10, 0x2c,
0xd4, 0x9a, 0x27, 0xf1, 0x02, 0x8c,
0x38, 0x18, 0x7f, 0x7f, 0x95, 0x65,
0xf1, 0xa9, 0x3b, 0x7d, 0x1f, 0x4f,
0x88, 0xb0, 0x65, 0x62, 0x63, 0x63,
0xaa, 0x82, 0xfc, 0x83, 0x3a, 0x3a,
0x46, 0x59, 0x6a, 0x89, 0xec, 0xa9,
0xb0, 0x4c, 0x5e, 0xbe, 0x46, 0x98,
0xd0, 0xd4, 0xb7, 0xe3, 0x1b, 0x30,
0x0b, 0xfb, 0xbb, 0x4f, 0x0b, 0xd3,
0xe4, 0xa0, 0x80, 0x54, 0xcb, 0x52,
0x0a, 0xe8, 0x03, 0x75, 0x8e, 0x96,
0xa4, 0x21, 0xaa, 0xbd, 0x7a, 0xfd,
0xfa, 0xf8, 0xaf, 0x42, 0xf6, 0x61,
0xd2, 0x93, 0xce, 0x66, 0x67, 0xe9,
0x02, 0xda, 0x81, 0x0b, 0xb0, 0x1e,
0x9e, 0x27, 0x57, 0x98, 0x18, 0x88,
0x35, 0x49, 0xc0, 0x88, 0x88, 0x59,
0xae, 0x2f, 0x66, 0x59, 0x31, 0x87,
0x88, 0xda ),
BIGINT ( 0xfe, 0x21, 0x7c, 0xf4, 0xbe, 0xae,
0x65, 0xda, 0x89, 0xd2, 0x26, 0xd6,
0x9c, 0x65, 0xc6, 0xb6, 0xb4, 0x0a,
0x84, 0x11, 0xe1, 0xe8, 0xba, 0xd8,
0x16, 0xcf, 0x60, 0x6c, 0x83, 0xa5,
0x4a, 0xbf, 0xa2, 0x24, 0x0b, 0x66,
0xda, 0xe2, 0x4e, 0x2d, 0xe5, 0x9e,
0xbf, 0xad, 0x5c, 0xa3, 0x1e, 0x5c,
0xbd, 0xe2, 0x5b, 0x46, 0xcf, 0xcc,
0xd5, 0xc9, 0x13, 0x95, 0xc3, 0xdb,
0x64, 0xbf, 0xeb, 0x31, 0xa9, 0x8a,
0x3b, 0xd2, 0x5d, 0x3b, 0x2e, 0xdc,
0x0c, 0xca, 0xab, 0xde, 0x92, 0xae,
0x45, 0x35, 0x96, 0xb0, 0xb7, 0xb9,
0xe6, 0xfe, 0x28, 0x0d, 0x10, 0x72,
0x53, 0x8e, 0x21, 0xc0, 0x33, 0x79,
0x01, 0x43, 0x8d, 0x77, 0xc4, 0xaa,
0xcf, 0x7f, 0xc3, 0xd1, 0xf5, 0xfd,
0x79, 0x81, 0xf6, 0x2e, 0xb7, 0xeb,
0x55, 0x5f, 0x74, 0xf0, 0x3a, 0xb9,
0x57, 0x07, 0x09, 0x97, 0xa5, 0x4c,
0x4a, 0x85 ),
BIGINT ( 0xd9, 0xb7, 0xb2, 0xd6, 0xeb, 0xf3,
0x66, 0xbe, 0x15, 0x64, 0xad, 0x2e,
0x9e, 0xc6, 0xaf, 0x5e, 0xaf, 0x40,
0x1e, 0x90, 0x82, 0x2f, 0x98 ),
BIGINT ( 0x12, 0x48, 0x31, 0x7f, 0x09, 0xbb,
0x8f, 0xd9, 0x02, 0x7e, 0x4a, 0xd0,
0x2f, 0x42, 0x7c, 0x17, 0x6e, 0x83,
0x74, 0x21, 0x95, 0x47, 0x7d, 0x93,
0x4a, 0xce, 0x34, 0x7c, 0xde, 0xc7,
0x8f, 0xf6, 0x28, 0x97, 0xba, 0x81,
0x9b, 0xcc, 0x54, 0x14, 0x7f, 0xd3,
0x93, 0x66, 0x41, 0x8c, 0x0e, 0x47,
0xee, 0xc5, 0x5e, 0xd6, 0x5f, 0x01,
0x62, 0x97, 0xf1, 0x2b, 0xee, 0x60,
0x5e, 0x82, 0x2c, 0x7b, 0x0a, 0xf2,
0xc3, 0x23, 0xbf, 0xb9, 0x83, 0xf7,
0x97, 0xf5, 0xca, 0x58, 0xd7, 0xf0,
0x87, 0x7b, 0xcb, 0x87, 0x69, 0x42,
0xbc, 0x05, 0xc4, 0xad, 0xbd, 0x82,
0xcf, 0x44, 0x16, 0x4f, 0x46, 0xe0,
0xde, 0x2f, 0xfa, 0x77, 0xec, 0xa4,
0x23, 0x7d, 0x47, 0x3e, 0x94, 0x19,
0x8b, 0xb8, 0x84, 0x81, 0x80, 0x6c,
0x1e, 0x31, 0xa3, 0x6d, 0x14, 0x94,
0x57, 0x28, 0x99, 0x08, 0x0a, 0xa7,
0x98, 0x4b ) );
bigint_mod_exp_ok ( BIGINT ( 0xda, 0x52, 0xfd, 0x44, 0x5d, 0x11,
0x60, 0x6c, 0xec, 0x87, 0xbf, 0x19,
0xb8, 0x46, 0xaa, 0x41, 0xfc, 0x10,
0xae, 0x47, 0xd6, 0x72, 0x42, 0x57,
0xc3, 0x05, 0xca, 0xe3, 0x59, 0x94,
0x82, 0x7c, 0xa1, 0xe0, 0xd2, 0x6b,
0x77, 0x71, 0x42, 0xa1, 0xf7, 0x84,
0xae, 0xf4, 0x6f, 0x44, 0x0d, 0x88,
0xa2, 0xc5, 0x45, 0x9b, 0x49, 0x36,
0xd4, 0x20, 0x3a, 0x7c, 0x92, 0xdb,
0x65, 0xd9, 0x20, 0xd6, 0x71, 0x22,
0x90, 0x70, 0xbf, 0xf3, 0x17, 0xe8,
0x2c, 0x10, 0xe9, 0x4c, 0x02, 0x69,
0x37, 0xa2, 0x91, 0x04, 0x46, 0x11,
0xdc, 0xab, 0x5b, 0x1e, 0x3e, 0x31,
0xd8, 0x69, 0xf8, 0x48, 0x84, 0x1f,
0x56, 0x46, 0xf1, 0xc0, 0x14, 0x3f,
0xcc, 0x5d, 0xe2, 0xf7, 0x8b, 0xa4,
0x9e, 0x94, 0x32, 0xaa, 0x3c, 0x5e,
0x21, 0x70, 0x00, 0x24, 0x2a, 0x1b,
0xec, 0x25, 0xb1, 0xb6, 0x83, 0x36,
0x5a, 0x95 ),
BIGINT ( 0x5e, 0xdc, 0x71, 0x1f, 0x5b, 0x55,
0xaa, 0xda, 0x56, 0xf5, 0x93, 0x9b,
0xe8, 0xfc, 0x6a, 0x80, 0xe1, 0xe3,
0x93, 0xe4, 0xc0, 0x58, 0x6f, 0x22,
0xce, 0x9d, 0x6f, 0x84, 0x4c, 0xd4,
0x12, 0x44, 0x57, 0x25, 0xca, 0xe5,
0x2b, 0x7c, 0x35, 0x88, 0xc7, 0x38,
0x25, 0x20, 0x9b, 0x57, 0xf2, 0xf2,
0x6c, 0x28, 0x47, 0x9c, 0x3f, 0x91,
0x1e, 0x3f, 0xe9, 0xeb, 0x50, 0xd6,
0xa7, 0x22, 0x88, 0x6c, 0x71, 0xe5,
0x62, 0x2a, 0xb7, 0xce, 0xbe, 0xf7,
0x1a, 0x8c, 0x52, 0xa6, 0xff, 0xb8,
0x34, 0x83, 0x7e, 0x04, 0xa8, 0x9c,
0xa8, 0xa7, 0xd1, 0x05, 0x8e, 0x13,
0x03, 0xe0, 0x49, 0xd8, 0x4a, 0xc4,
0x4d, 0x38, 0x21, 0x5b, 0x62, 0xc2,
0x38, 0x23, 0x7c, 0x9e, 0xf1, 0xe9,
0xb6, 0x9a, 0x75, 0x42, 0x14, 0x99,
0x63, 0x36, 0x13, 0x4c, 0x2d, 0x3a,
0x77, 0xd4, 0x74, 0xb7, 0x30, 0xb2,
0x00, 0x0f ),
BIGINT ( 0xe3, 0xe5, 0x3b, 0xb5, 0x92, 0x5a,
0xc6, 0xfa, 0x8f, 0xe8, 0x00, 0xb9,
0x5c, 0xa0, 0xb6, 0x3e, 0x5e, 0x14,
0x12, 0xa9, 0xdd, 0x2a, 0x3d, 0x4d,
0xa3, 0x91, 0x6a, 0x56, 0x99, 0xc2,
0x6c, 0x8e, 0xda, 0xb0, 0x5a, 0x2a,
0x37, 0x55, 0x8b, 0xd3, 0x9b, 0xb6,
0x1d, 0x49, 0x7d, 0x81, 0x76, 0x1c,
0x2e, 0xb9, 0x92, 0x6d, 0xfa, 0x54,
0x53, 0xfc, 0x74, 0x9b, 0x6b, 0x63,
0x95, 0x1a, 0x89, 0xcc, 0xbd, 0x36,
0xc5, 0x31, 0x7f, 0xf5, 0x31, 0x69,
0x40, 0xd5, 0x7b, 0x94, 0x5d, 0xa9,
0xd1, 0x34, 0x95, 0xa1, 0x8b, 0xa5,
0xb5, 0x83, 0xda, 0xb5, 0x9d, 0x5b,
0x74, 0x41, 0xad, 0x81, 0x45, 0x40,
0x9b, 0xc3, 0xe8, 0xfe, 0x47, 0xdc,
0xb0, 0xc3, 0x34, 0x5d, 0xf6, 0x3c,
0x1d, 0x07, 0x76, 0xd9, 0x25, 0xca,
0xa2, 0x39, 0x6c, 0xa8, 0xae, 0x30,
0x4a, 0xde, 0xfb, 0xeb, 0x19, 0x80,
0x5e, 0x49 ),
BIGINT ( 0x4b, 0x0e, 0x74, 0xb8, 0xa7, 0x92,
0x74, 0xd9, 0x50, 0xf6, 0x1b, 0x67,
0x76, 0x76, 0x56, 0x6c, 0x09, 0x9c,
0x01, 0xda, 0xaf, 0xa3, 0xca, 0xb2,
0x12, 0x85, 0x52, 0x24, 0xe9, 0x7e,
0x2b, 0xf2, 0x6e, 0xe9, 0x1a, 0x10,
0x5d, 0xa0, 0x25, 0x46, 0x8f, 0x2a,
0x95, 0x62, 0x50, 0xb6, 0x66, 0x43,
0x37, 0x8b, 0xcb, 0x05, 0xf8, 0x61,
0x59, 0xf9, 0xdd, 0xd2, 0x68, 0x72,
0xfa, 0x88, 0x13, 0x36, 0xd8, 0x24,
0x73, 0xec, 0x47, 0x44, 0xdd, 0x45,
0x8a, 0x59, 0xd2, 0xbd, 0x43, 0xe3,
0x05, 0x16, 0xd5, 0x9b, 0x1c, 0x8a,
0x4b, 0x07, 0xda, 0x58, 0x0d, 0x4a,
0x4e, 0xe7, 0x15, 0xfc, 0xbd, 0x95,
0xf7, 0x18, 0xa5, 0xa7, 0x93, 0xff,
0xf8, 0x1f, 0xd4, 0x6b, 0x07, 0xc6,
0x5d, 0x90, 0x73, 0x57, 0x57, 0x37,
0xfa, 0x83, 0xd4, 0x7c, 0xe9, 0x77,
0x46, 0x91, 0x3a, 0x50, 0x0d, 0x6a,
0x25, 0xd0 ) );
}
/** Big integer self-test */
struct self_test bigint_test __self_test = {
.name = "bigint",
.exec = bigint_test_exec,
};