php.net | support | documentation | report a bug | advanced search | search howto | statistics | random bug | login | |
Patch gmp-memory.patch for GNU MP related Bug #63595Patch version 2014-10-11 06:50 UTC Return to Bug #63595 | Download this patchThis patch renders other patches obsolete Obsolete patches: Patch Revisions:Developer: remi@php.net--- gmp.c.old 2014-10-11 08:03:14.764951256 +0200 +++ gmp.c 2014-10-11 08:49:17.590456127 +0200 @@ -352,6 +352,26 @@ static inline void gmp_zval_unary_ui_op( #define gmp_unary_opl(op) _gmp_unary_opl(INTERNAL_FUNCTION_PARAM_PASSTHRU, op) #define gmp_unary_ui_op(op) _gmp_unary_ui_op(INTERNAL_FUNCTION_PARAM_PASSTHRU, op) +static void *(*_save_malloc) (size_t); +static void *(*_save_realloc) (void *, size_t, size_t); +static void (*_save_free) (void *, size_t); +static int _save_count = 0; + +#define GMP_SET_MEMORY do { \ + if (_save_count == 0) { \ + mp_get_memory_functions(&_save_malloc, &_save_realloc, &_save_free); \ + mp_set_memory_functions(gmp_emalloc, gmp_erealloc, gmp_efree); \ + } \ + _save_count++; \ +} while (0) + +#define GMP_END_MEMORY do { \ + _save_count--; \ + if (_save_count == 0) { \ + mp_set_memory_functions(_save_malloc, _save_realloc, _save_free); \ + } \ +} while (0) + /* {{{ gmp_emalloc */ static void *gmp_emalloc(size_t size) @@ -391,7 +411,9 @@ static inline long gmp_get_long(zval *zv static void gmp_free_object_storage(gmp_object *intern TSRMLS_DC) /* {{{ */ { + GMP_SET_MEMORY; mpz_clear(intern->num); + GMP_END_MEMORY; zend_object_std_dtor(&intern->std TSRMLS_CC); efree(intern); @@ -406,7 +428,10 @@ static inline zend_object_value gmp_crea zend_object_std_init(&intern->std, ce TSRMLS_CC); object_properties_init(&intern->std, ce); + GMP_SET_MEMORY; mpz_init(intern->num); + GMP_END_MEMORY; + *gmpnum_target = intern->num; retval.handle = zend_objects_store_put( @@ -545,6 +570,7 @@ static void shift_operator_helper(gmp_bi static int gmp_do_operation_ex(zend_uchar opcode, zval *result, zval *op1, zval *op2 TSRMLS_DC) /* {{{ */ { + GMP_SET_MEMORY; switch (opcode) { case ZEND_ADD: DO_BINARY_UI_OP(mpz_add); @@ -575,8 +601,10 @@ static int gmp_do_operation_ex(zend_ucha DO_UNARY_OP(mpz_com); default: + GMP_END_MEMORY; return FAILURE; } + GMP_END_MEMORY; } /* }}} */ @@ -602,7 +630,10 @@ static int gmp_do_operation(zend_uchar o static int gmp_compare(zval *result, zval *op1, zval *op2 TSRMLS_DC) /* {{{ */ { + GMP_SET_MEMORY; gmp_cmp(result, op1, op2 TSRMLS_CC); + GMP_END_MEMORY; + if (Z_TYPE_P(result) == IS_BOOL) { ZVAL_LONG(result, 1); } @@ -616,6 +647,7 @@ static int gmp_serialize(zval *object, u smart_str buf = {0}; zval zv, *zv_ptr = &zv; php_serialize_data_t serialize_data = (php_serialize_data_t) data; + GMP_SET_MEMORY; PHP_VAR_SERIALIZE_INIT(serialize_data); INIT_PZVAL(zv_ptr); @@ -632,6 +664,7 @@ static int gmp_serialize(zval *object, u *buffer = (unsigned char *) buf.c; *buf_len = buf.len; + GMP_END_MEMORY; return SUCCESS; } /* }}} */ @@ -643,6 +676,7 @@ static int gmp_unserialize(zval **object zval zv, *zv_ptr = &zv; int retval = FAILURE; php_unserialize_data_t unserialize_data = (php_unserialize_data_t) data; + GMP_SET_MEMORY; PHP_VAR_UNSERIALIZE_INIT(unserialize_data); gmp_create_ex(*object, &gmpnum TSRMLS_CC); @@ -679,6 +713,7 @@ static int gmp_unserialize(zval **object exit: zval_dtor(&zv); PHP_VAR_UNSERIALIZE_DESTROY(unserialize_data); + GMP_END_MEMORY; return retval; } /* }}} */ @@ -723,7 +758,8 @@ ZEND_MINIT_FUNCTION(gmp) REGISTER_LONG_CONSTANT("GMP_BIG_ENDIAN", GMP_BIG_ENDIAN, CONST_CS | CONST_PERSISTENT); REGISTER_LONG_CONSTANT("GMP_NATIVE_ENDIAN", GMP_NATIVE_ENDIAN, CONST_CS | CONST_PERSISTENT); - mp_set_memory_functions(gmp_emalloc, gmp_erealloc, gmp_efree); + // mp_set_memory_functions(gmp_emalloc, gmp_erealloc, gmp_efree); + _save_malloc = NULL; return SUCCESS; } @@ -734,7 +770,9 @@ ZEND_MINIT_FUNCTION(gmp) ZEND_MODULE_DEACTIVATE_D(gmp) { if (GMPG(rand_initialized)) { + GMP_SET_MEMORY; gmp_randclear(GMPG(rand_state)); + GMP_END_MEMORY; GMPG(rand_initialized) = 0; } @@ -1085,12 +1123,15 @@ ZEND_FUNCTION(gmp_init) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Bad base for conversion: %ld (should be between 2 and %d)", base, MAX_BASE); RETURN_FALSE; } + GMP_SET_MEMORY; INIT_GMP_RETVAL(gmpnumber); if (convert_to_gmp(gmpnumber, number_arg, base TSRMLS_CC) == FAILURE) { zval_dtor(return_value); + GMP_END_MEMORY; RETURN_FALSE; } + GMP_END_MEMORY; } /* }}} */ @@ -1150,20 +1191,24 @@ ZEND_FUNCTION(gmp_import) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s|ll", &data, &data_len, &size, &options) == FAILURE) { return; } + GMP_SET_MEMORY; if (gmp_import_export_validate(size, options, &order, &endian TSRMLS_CC) == FAILURE) { + GMP_END_MEMORY; RETURN_FALSE; } if ((data_len % size) != 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Input length must be a multiple of word size"); + GMP_END_MEMORY; RETURN_FALSE; } INIT_GMP_RETVAL(gmpnumber); mpz_import(gmpnumber, data_len / size, order, size, endian, 0, data); + GMP_END_MEMORY; } /* }}} */ @@ -1181,14 +1226,17 @@ ZEND_FUNCTION(gmp_export) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z|ll", &gmpnumber_arg, &size, &options) == FAILURE) { return; } + GMP_SET_MEMORY; if (gmp_import_export_validate(size, options, &order, &endian TSRMLS_CC) == FAILURE) { + GMP_END_MEMORY; RETURN_FALSE; } FETCH_GMP_ZVAL(gmpnumber, gmpnumber_arg, temp_a); if (mpz_sgn(gmpnumber) == 0) { + GMP_END_MEMORY; RETURN_EMPTY_STRING(); } else { size_t bits_per_word = size * 8; @@ -1199,10 +1247,12 @@ ZEND_FUNCTION(gmp_export) mpz_export(out_string, NULL, order, size, endian, 0, gmpnumber); out_string[out_len] = '\0'; + GMP_END_MEMORY; RETURN_STRINGL(out_string, out_len, 0); } FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1215,12 +1265,14 @@ ZEND_FUNCTION(gmp_intval) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &gmpnumber_arg) == FAILURE){ return; } + GMP_SET_MEMORY; if (IS_GMP(gmpnumber_arg)) { RETVAL_LONG(mpz_get_si(GET_GMP_FROM_ZVAL(gmpnumber_arg))); } else { RETVAL_LONG(gmp_get_long(gmpnumber_arg)); } + GMP_END_MEMORY; } /* }}} */ @@ -1236,6 +1288,7 @@ ZEND_FUNCTION(gmp_strval) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z|l", &gmpnumber_arg, &base) == FAILURE) { return; } + GMP_SET_MEMORY; #if MAX_BASE == 62 /* Although the maximum base in general in GMP >= 4.2 is 62, mpz_get_str() @@ -1254,6 +1307,7 @@ ZEND_FUNCTION(gmp_strval) gmp_strval(return_value, gmpnum, base); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1261,7 +1315,9 @@ ZEND_FUNCTION(gmp_strval) Add a and b */ ZEND_FUNCTION(gmp_add) { + GMP_SET_MEMORY; gmp_binary_ui_op(mpz_add, mpz_add_ui); + GMP_END_MEMORY; } /* }}} */ @@ -1269,7 +1325,9 @@ ZEND_FUNCTION(gmp_add) Subtract b from a */ ZEND_FUNCTION(gmp_sub) { + GMP_SET_MEMORY; gmp_binary_ui_op(mpz_sub, mpz_sub_ui); + GMP_END_MEMORY; } /* }}} */ @@ -1277,7 +1335,9 @@ ZEND_FUNCTION(gmp_sub) Multiply a and b */ ZEND_FUNCTION(gmp_mul) { + GMP_SET_MEMORY; gmp_binary_ui_op(mpz_mul, mpz_mul_ui); + GMP_END_MEMORY; } /* }}} */ @@ -1291,6 +1351,7 @@ ZEND_FUNCTION(gmp_div_qr) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz|l", &a_arg, &b_arg, &round) == FAILURE) { return; } + GMP_SET_MEMORY; switch (round) { case GMP_ROUND_ZERO: @@ -1304,8 +1365,10 @@ ZEND_FUNCTION(gmp_div_qr) break; default: php_error_docref(NULL TSRMLS_CC, E_WARNING, "Invalid rounding mode"); + GMP_END_MEMORY; RETURN_FALSE; } + GMP_END_MEMORY; } /* }}} */ @@ -1319,6 +1382,7 @@ ZEND_FUNCTION(gmp_div_r) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz|l", &a_arg, &b_arg, &round) == FAILURE) { return; } + GMP_SET_MEMORY; switch (round) { case GMP_ROUND_ZERO: @@ -1332,8 +1396,10 @@ ZEND_FUNCTION(gmp_div_r) break; default: php_error_docref(NULL TSRMLS_CC, E_WARNING, "Invalid rounding mode"); + GMP_END_MEMORY; RETURN_FALSE; } + GMP_END_MEMORY; } /* }}} */ @@ -1347,6 +1413,7 @@ ZEND_FUNCTION(gmp_div_q) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz|l", &a_arg, &b_arg, &round) == FAILURE) { return; } + GMP_SET_MEMORY; switch (round) { case GMP_ROUND_ZERO: @@ -1360,9 +1427,10 @@ ZEND_FUNCTION(gmp_div_q) break; default: php_error_docref(NULL TSRMLS_CC, E_WARNING, "Invalid rounding mode"); + GMP_END_MEMORY; RETURN_FALSE; } - + GMP_END_MEMORY; } /* }}} */ @@ -1370,7 +1438,9 @@ ZEND_FUNCTION(gmp_div_q) Computes a modulo b */ ZEND_FUNCTION(gmp_mod) { + GMP_SET_MEMORY; gmp_binary_ui_op_no_zero(mpz_mod, (gmp_binary_ui_op_t) mpz_mod_ui); + GMP_END_MEMORY; } /* }}} */ @@ -1378,7 +1448,9 @@ ZEND_FUNCTION(gmp_mod) Divide a by b using exact division algorithm */ ZEND_FUNCTION(gmp_divexact) { + GMP_SET_MEMORY; gmp_binary_ui_op_no_zero(mpz_divexact, NULL); + GMP_END_MEMORY; } /* }}} */ @@ -1386,7 +1458,9 @@ ZEND_FUNCTION(gmp_divexact) Negates a number */ ZEND_FUNCTION(gmp_neg) { + GMP_SET_MEMORY; gmp_unary_op(mpz_neg); + GMP_END_MEMORY; } /* }}} */ @@ -1394,7 +1468,9 @@ ZEND_FUNCTION(gmp_neg) Calculates absolute value */ ZEND_FUNCTION(gmp_abs) { + GMP_SET_MEMORY; gmp_unary_op(mpz_abs); + GMP_END_MEMORY; } /* }}} */ @@ -1407,21 +1483,25 @@ ZEND_FUNCTION(gmp_fact) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &a_arg) == FAILURE){ return; } + GMP_SET_MEMORY; if (IS_GMP(a_arg)) { mpz_ptr gmpnum_tmp = GET_GMP_FROM_ZVAL(a_arg); if (mpz_sgn(gmpnum_tmp) < 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Number has to be greater than or equal to 0"); + GMP_END_MEMORY; RETURN_FALSE; } } else { if (gmp_get_long(a_arg) < 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Number has to be greater than or equal to 0"); + GMP_END_MEMORY; RETURN_FALSE; } } gmp_zval_unary_ui_op(return_value, a_arg, mpz_fac_ui TSRMLS_CC); + GMP_END_MEMORY; } /* }}} */ @@ -1442,6 +1522,7 @@ ZEND_FUNCTION(gmp_pow) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Negative exponent not supported"); RETURN_FALSE; } + GMP_SET_MEMORY; INIT_GMP_RETVAL(gmpnum_result); if (Z_TYPE_P(base_arg) == IS_LONG && Z_LVAL_P(base_arg) >= 0) { @@ -1451,6 +1532,7 @@ ZEND_FUNCTION(gmp_pow) mpz_pow_ui(gmpnum_result, gmpnum_base, exp); FREE_GMP_TEMP(temp_base); } + GMP_END_MEMORY; } /* }}} */ @@ -1466,6 +1548,7 @@ ZEND_FUNCTION(gmp_powm) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zzz", &base_arg, &exp_arg, &mod_arg) == FAILURE){ return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_base, base_arg, temp_base); @@ -1478,6 +1561,7 @@ ZEND_FUNCTION(gmp_powm) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Second parameter cannot be less than 0"); FREE_GMP_TEMP(temp_base); FREE_GMP_TEMP(temp_exp); + GMP_END_MEMORY; RETURN_FALSE; } } @@ -1488,6 +1572,7 @@ ZEND_FUNCTION(gmp_powm) FREE_GMP_TEMP(temp_base); FREE_GMP_TEMP(temp_exp); FREE_GMP_TEMP(temp_mod); + GMP_END_MEMORY; RETURN_FALSE; } @@ -1501,6 +1586,7 @@ ZEND_FUNCTION(gmp_powm) FREE_GMP_TEMP(temp_base); FREE_GMP_TEMP(temp_mod); + GMP_END_MEMORY; } /* }}} */ @@ -1515,18 +1601,21 @@ ZEND_FUNCTION(gmp_sqrt) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &a_arg) == FAILURE){ return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); if (mpz_sgn(gmpnum_a) < 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Number has to be greater than or equal to 0"); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; RETURN_FALSE; } INIT_GMP_RETVAL(gmpnum_result); mpz_sqrt(gmpnum_result, gmpnum_a); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1541,12 +1630,14 @@ ZEND_FUNCTION(gmp_sqrtrem) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &a_arg) == FAILURE){ return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); if (mpz_sgn(gmpnum_a) < 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Number has to be greater than or equal to 0"); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; RETURN_FALSE; } @@ -1556,6 +1647,7 @@ ZEND_FUNCTION(gmp_sqrtrem) mpz_sqrtrem(gmpnum_result1, gmpnum_result2, gmpnum_a); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1576,18 +1668,21 @@ ZEND_FUNCTION(gmp_root) php_error_docref(NULL TSRMLS_CC, E_WARNING, "The root must be positive"); RETURN_FALSE; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); if (nth % 2 == 0 && mpz_sgn(gmpnum_a) < 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Can't take even root of negative number"); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; RETURN_FALSE; } INIT_GMP_RETVAL(gmpnum_result); mpz_root(gmpnum_result, gmpnum_a, (unsigned long) nth); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1608,12 +1703,14 @@ ZEND_FUNCTION(gmp_rootrem) php_error_docref(NULL TSRMLS_CC, E_WARNING, "The root must be positive"); RETURN_FALSE; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); if (nth % 2 == 0 && mpz_sgn(gmpnum_a) < 0) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Can't take even root of negative number"); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; RETURN_FALSE; } @@ -1631,6 +1728,7 @@ ZEND_FUNCTION(gmp_rootrem) #endif FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1645,11 +1743,13 @@ ZEND_FUNCTION(gmp_perfect_square) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z", &a_arg) == FAILURE){ return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); RETVAL_BOOL((mpz_perfect_square_p(gmpnum_a) != 0)); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1665,11 +1765,13 @@ ZEND_FUNCTION(gmp_prob_prime) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "z|l", &gmpnumber_arg, &reps) == FAILURE) { return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, gmpnumber_arg, temp_a); RETVAL_LONG(mpz_probab_prime_p(gmpnum_a, reps)); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1677,7 +1779,9 @@ ZEND_FUNCTION(gmp_prob_prime) Computes greatest common denominator (gcd) of a and b */ ZEND_FUNCTION(gmp_gcd) { + GMP_SET_MEMORY; gmp_binary_ui_op(mpz_gcd, (gmp_binary_ui_op_t) mpz_gcd_ui); + GMP_END_MEMORY; } /* }}} */ @@ -1692,6 +1796,7 @@ ZEND_FUNCTION(gmp_gcdext) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz", &a_arg, &b_arg) == FAILURE){ return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); FETCH_GMP_ZVAL_DEP(gmpnum_b, b_arg, temp_b, temp_a); @@ -1704,6 +1809,7 @@ ZEND_FUNCTION(gmp_gcdext) mpz_gcdext(gmpnum_g, gmpnum_s, gmpnum_t, gmpnum_a, gmpnum_b); FREE_GMP_TEMP(temp_a); FREE_GMP_TEMP(temp_b); + GMP_END_MEMORY; } /* }}} */ @@ -1719,6 +1825,7 @@ ZEND_FUNCTION(gmp_invert) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zz", &a_arg, &b_arg) == FAILURE){ return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); FETCH_GMP_ZVAL_DEP(gmpnum_b, b_arg, temp_b, temp_a); @@ -1729,8 +1836,10 @@ ZEND_FUNCTION(gmp_invert) FREE_GMP_TEMP(temp_b); if (!res) { zval_dtor(return_value); + GMP_END_MEMORY; RETURN_FALSE; } + GMP_END_MEMORY; } /* }}} */ @@ -1738,7 +1847,9 @@ ZEND_FUNCTION(gmp_invert) Computes Jacobi symbol */ ZEND_FUNCTION(gmp_jacobi) { + GMP_SET_MEMORY; gmp_binary_opl(mpz_jacobi); + GMP_END_MEMORY; } /* }}} */ @@ -1746,7 +1857,9 @@ ZEND_FUNCTION(gmp_jacobi) Computes Legendre symbol */ ZEND_FUNCTION(gmp_legendre) { + GMP_SET_MEMORY; gmp_binary_opl(mpz_legendre); + GMP_END_MEMORY; } /* }}} */ @@ -1760,7 +1873,9 @@ ZEND_FUNCTION(gmp_cmp) return; } + GMP_SET_MEMORY; gmp_cmp(return_value, a_arg, b_arg TSRMLS_CC); + GMP_END_MEMORY; } /* }}} */ @@ -1777,10 +1892,12 @@ ZEND_FUNCTION(gmp_sign) return; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); RETVAL_LONG(mpz_sgn(gmpnum_a)); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1794,6 +1911,7 @@ ZEND_FUNCTION(gmp_random) if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|l", &limiter) == FAILURE) { return; } + GMP_SET_MEMORY; INIT_GMP_RETVAL(gmpnum_result); @@ -1811,6 +1929,7 @@ ZEND_FUNCTION(gmp_random) #else mpz_urandomb(gmpnum_result, GMPG(rand_state), GMP_ABS (limiter) * __GMP_BITS_PER_MP_LIMB); #endif + GMP_END_MEMORY; } /* }}} */ @@ -1818,7 +1937,9 @@ ZEND_FUNCTION(gmp_random) Calculates logical AND of a and b */ ZEND_FUNCTION(gmp_and) { + GMP_SET_MEMORY; gmp_binary_op(mpz_and); + GMP_END_MEMORY; } /* }}} */ @@ -1826,7 +1947,9 @@ ZEND_FUNCTION(gmp_and) Calculates logical OR of a and b */ ZEND_FUNCTION(gmp_or) { + GMP_SET_MEMORY; gmp_binary_op(mpz_ior); + GMP_END_MEMORY; } /* }}} */ @@ -1834,7 +1957,9 @@ ZEND_FUNCTION(gmp_or) Calculates one's complement of a */ ZEND_FUNCTION(gmp_com) { + GMP_SET_MEMORY; gmp_unary_op(mpz_com); + GMP_END_MEMORY; } /* }}} */ @@ -1842,7 +1967,9 @@ ZEND_FUNCTION(gmp_com) Finds next prime of a */ ZEND_FUNCTION(gmp_nextprime) { + GMP_SET_MEMORY; gmp_unary_op(mpz_nextprime); + GMP_END_MEMORY; } /* }}} */ @@ -1850,7 +1977,9 @@ ZEND_FUNCTION(gmp_nextprime) Calculates logical exclusive OR of a and b */ ZEND_FUNCTION(gmp_xor) { + GMP_SET_MEMORY; gmp_binary_op(mpz_xor); + GMP_END_MEMORY; } /* }}} */ @@ -1871,6 +2000,7 @@ ZEND_FUNCTION(gmp_setbit) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Index must be greater than or equal to zero"); return; } + GMP_SET_MEMORY; gmpnum_a = GET_GMP_FROM_ZVAL(a_arg); @@ -1879,6 +2009,7 @@ ZEND_FUNCTION(gmp_setbit) } else { mpz_clrbit(gmpnum_a, index); } + GMP_END_MEMORY; } /* }}} */ @@ -1898,9 +2029,11 @@ ZEND_FUNCTION(gmp_clrbit) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Index must be greater than or equal to zero"); return; } + GMP_SET_MEMORY; gmpnum_a = GET_GMP_FROM_ZVAL(a_arg); mpz_clrbit(gmpnum_a, index); + GMP_END_MEMORY; } /* }}} */ @@ -1921,10 +2054,12 @@ ZEND_FUNCTION(gmp_testbit) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Index must be greater than or equal to zero"); RETURN_FALSE; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); RETVAL_BOOL(mpz_tstbit(gmpnum_a, index)); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1932,7 +2067,9 @@ ZEND_FUNCTION(gmp_testbit) Calculates the population count of a */ ZEND_FUNCTION(gmp_popcount) { + GMP_SET_MEMORY; gmp_unary_opl((gmp_unary_opl_t) mpz_popcount); + GMP_END_MEMORY; } /* }}} */ @@ -1940,7 +2077,9 @@ ZEND_FUNCTION(gmp_popcount) Calculates hamming distance between a and b */ ZEND_FUNCTION(gmp_hamdist) { + GMP_SET_MEMORY; gmp_binary_opl((gmp_binary_opl_t) mpz_hamdist); + GMP_END_MEMORY; } /* }}} */ @@ -1961,11 +2100,13 @@ ZEND_FUNCTION(gmp_scan0) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Starting index must be greater than or equal to zero"); RETURN_FALSE; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); RETVAL_LONG(mpz_scan0(gmpnum_a, start)); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ @@ -1986,11 +2127,13 @@ ZEND_FUNCTION(gmp_scan1) php_error_docref(NULL TSRMLS_CC, E_WARNING, "Starting index must be greater than or equal to zero"); RETURN_FALSE; } + GMP_SET_MEMORY; FETCH_GMP_ZVAL(gmpnum_a, a_arg, temp_a); RETVAL_LONG(mpz_scan1(gmpnum_a, start)); FREE_GMP_TEMP(temp_a); + GMP_END_MEMORY; } /* }}} */ |
Copyright © 2001-2024 The PHP Group All rights reserved. |
Last updated: Thu Nov 21 14:01:29 2024 UTC |