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
{