diff --git a/include/crypto.h b/include/crypto.h index 6dcce70..ed55460 100644 --- a/include/crypto.h +++ b/include/crypto.h @@ -29,7 +29,7 @@ extern "C" { #define WHY2_SUM_MOD_PRIME 4294967295UL //PRIME FOR SUM MODULUS //FUNCTIONS -unsigned long why2_sum_segment(char *input); //CALCULATE SUM++ FOR input; USED FOR PADDING SEED +unsigned long long why2_sum_segment(char *input); //CALCULATE SUM++ FOR input; USED FOR PADDING SEED #ifdef __cplusplus } diff --git a/src/core/lib/utils/crypto.c b/src/core/lib/utils/crypto.c index 6c3dace..48718c0 100644 --- a/src/core/lib/utils/crypto.c +++ b/src/core/lib/utils/crypto.c @@ -21,11 +21,11 @@ along with this program. If not, see . #include #include -unsigned long why2_sum_segment(char *input) //I ABSOLUTELY DO NOT RECOMMEND USING THIS WITH LARGE KEYS!!! +unsigned long long why2_sum_segment(char *input) //I ABSOLUTELY DO NOT RECOMMEND USING THIS WITH LARGE KEYS!!! { unsigned long input_size = strlen(input); unsigned long segmented_input_size = ceil(input_size / (double) WHY2_SUM_SEGMENT_SIZE) * WHY2_SUM_SEGMENT_SIZE; //CALCULATE CLOSEST 32*n (OR WHY2_SUM_SEGMENT_SIZE*n, IF YOU WILL) TO input - unsigned long output = 0; + unsigned long long output = 0; for (unsigned long i = 0; i < segmented_input_size / WHY2_SUM_SEGMENT_SIZE; i++) //DIVIDE buffer INTO SEGMENTS, XOR EACH OTHER AND ADD TO output {