/* * Copyright (C) 2012 Michael Brown . * * 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 #include #include #include /** 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 ); } void 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 ); bigint_add ( addend, value ); } void 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 ); 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 ( const bigint_element_t *minuend0, unsigned int minuend_size, const bigint_element_t *modulus0, unsigned int modulus_size, bigint_element_t *result0, void *tmp ) { const bigint_t ( minuend_size ) __attribute__ (( may_alias )) *minuend = ( ( const void * ) minuend0 ); const bigint_t ( modulus_size ) __attribute__ (( may_alias )) *modulus = ( ( const void * ) modulus0 ); bigint_t ( modulus_size ) __attribute__ (( may_alias )) *result = ( ( void * ) result0 ); bigint_reduce ( minuend, modulus, result, tmp ); } void bigint_mod_invert_sample ( const bigint_element_t *invertend0, bigint_element_t *inverse0, unsigned int size, void *tmp ) { 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, tmp ); } 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 */ #define bigint_add_ok( addend, value, expected ) 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 ) ); \ bigint_t ( size ) addend_temp; \ bigint_t ( size ) value_temp; \ {} /* 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 ) ); \ 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 ); \ } 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 */ #define bigint_subtract_ok( subtrahend, value, expected ) 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; \ {} /* 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 ) ); \ 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 ); \ } 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 minuend Big integer to be reduced * @v modulus Big integer modulus * @v expected Big integer expected result */ #define bigint_reduce_ok( minuend, modulus, expected ) do { \ static const uint8_t minuend_raw[] = minuend; \ static const uint8_t modulus_raw[] = modulus; \ static const uint8_t expected_raw[] = expected; \ uint8_t result_raw[ sizeof ( expected_raw ) ]; \ unsigned int minuend_size = \ bigint_required_size ( sizeof ( minuend_raw ) ); \ unsigned int modulus_size = \ bigint_required_size ( sizeof ( modulus_raw ) ); \ bigint_t ( minuend_size ) minuend_temp; \ bigint_t ( modulus_size ) modulus_temp; \ bigint_t ( modulus_size ) result_temp; \ size_t tmp_len = bigint_reduce_tmp_len ( &minuend_temp ); \ uint8_t tmp[tmp_len]; \ {} /* Fix emacs alignment */ \ \ assert ( bigint_size ( &result_temp ) == \ bigint_size ( &modulus_temp ) ); \ bigint_init ( &minuend_temp, minuend_raw, \ sizeof ( minuend_raw ) ); \ bigint_init ( &modulus_temp, modulus_raw, \ sizeof ( modulus_raw ) ); \ DBG ( "Modular reduce:\n" ); \ DBG_HDA ( 0, &minuend_temp, sizeof ( minuend_temp ) ); \ DBG_HDA ( 0, &modulus_temp, sizeof ( modulus_temp ) ); \ bigint_reduce ( &minuend_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 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 size = \ bigint_required_size ( sizeof ( invertend_raw ) ); \ bigint_t ( size ) invertend_temp; \ bigint_t ( size ) inverse_temp; \ size_t tmp_len = bigint_mod_invert_tmp_len ( &invertend_temp ); \ uint8_t tmp[tmp_len]; \ {} /* Fix emacs alignment */ \ \ assert ( bigint_size ( &invertend_temp ) == \ bigint_size ( &inverse_temp ) ); \ 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, tmp ); \ 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 ) ); bigint_add_ok ( BIGINT ( 0xc5, 0x7b ), BIGINT ( 0xd6, 0xb1 ), BIGINT ( 0x9c, 0x2c ) ); bigint_add_ok ( BIGINT ( 0xf9, 0xd9, 0xdc ), BIGINT ( 0x6d, 0x4b, 0xca ), BIGINT ( 0x67, 0x25, 0xa6 ) ); bigint_add_ok ( BIGINT ( 0xdd, 0xc2, 0x20, 0x5f ), BIGINT ( 0x80, 0x32, 0xc4, 0xb0 ), BIGINT ( 0x5d, 0xf4, 0xe5, 0x0f ) ); 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 ) ); 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 ) ); bigint_subtract_ok ( BIGINT ( 0x83 ), BIGINT ( 0x50 ), BIGINT ( 0xcd ) ); bigint_subtract_ok ( BIGINT ( 0x2c, 0x7c ), BIGINT ( 0x49, 0x0e ), BIGINT ( 0x1c, 0x92 ) ); bigint_subtract_ok ( BIGINT ( 0x9c, 0x30, 0xbf ), BIGINT ( 0xde, 0x4e, 0x07 ), BIGINT ( 0x42, 0x1d, 0x48 ) ); bigint_subtract_ok ( BIGINT ( 0xbb, 0x77, 0x32, 0x5a ), BIGINT ( 0x5a, 0xd5, 0xfe, 0x28 ), BIGINT ( 0x9f, 0x5e, 0xcb, 0xce ) ); 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 ) ); 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 ) ); 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 ) ); 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 ( 0x00 ), BIGINT ( 0xaf ), BIGINT ( 0x00 ) ); bigint_reduce_ok ( BIGINT ( 0xab ), BIGINT ( 0xab ), BIGINT ( 0x00 ) ); bigint_reduce_ok ( BIGINT ( 0x1d, 0x97, 0x63, 0xc9, 0x97, 0xcd, 0x43, 0xcb, 0x8e, 0x71, 0xac, 0x41, 0xdd ), 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_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 ( 0xf9, 0x78, 0x96, 0x39, 0xee, 0x98, 0x42, 0x6a, 0xb8, 0x74, 0x0b, 0xe8, 0x5c, 0x76, 0x34, 0xaf ), BIGINT ( 0xf3, 0x65, 0x35, 0x41, 0x66, 0x65 ), BIGINT ( 0xb3, 0x07, 0xe8, 0xb7, 0x01, 0xf6 ) ); bigint_reduce_ok ( BIGINT ( 0xfe, 0x30, 0xe1, 0xc6, 0x65, 0x97, 0x48, 0x2e, 0x94, 0xd4 ), BIGINT ( 0x47, 0xaa, 0x88, 0x00, 0xd0, 0x30, 0x62, 0xfb, 0x5d, 0x55 ), 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 ( 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_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, };