Skip to content

Commit

Permalink
Fix int overflow issue of progress variable (#186)
Browse files Browse the repository at this point in the history
  • Loading branch information
var77 authored Oct 1, 2023
1 parent 29af187 commit 57876ef
Showing 1 changed file with 7 additions and 7 deletions.
14 changes: 7 additions & 7 deletions src/hnsw/external_index.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ static uint32 UsearchNodeBytes(usearch_metadata_t *metadata, int vector_bytes, i
}

static char *extract_node(char *data,
int progress,
uint64 progress,
int dim,
usearch_metadata_t *metadata,
/*->>output*/ int *node_size,
Expand Down Expand Up @@ -107,7 +107,7 @@ void StoreExternalIndexBlockMapGroup(Relation index,
HnswIndexHeaderPage *headerp,
ForkNumber forkNum,
char *data,
int *progress,
uint64 *progress,
int dimension,
int first_node_index,
size_t num_added_vectors,
Expand Down Expand Up @@ -275,11 +275,11 @@ void StoreExternalIndex(Relation index,
memcpy(headerp->usearch_header, data, USEARCH_HEADER_SIZE);
((PageHeader)header_page)->pd_lower = ((char *)headerp + sizeof(HnswIndexHeaderPage)) - (char *)header_page;

int progress = USEARCH_HEADER_SIZE; // usearch header size
int blockmap_groupno = 0;
int group_node_first_index = 0;
int num_added_vectors_remaining = (int)num_added_vectors;
int batch_size = HNSW_BLOCKMAP_BLOCKS_PER_PAGE;
uint64 progress = USEARCH_HEADER_SIZE; // usearch header size
int blockmap_groupno = 0;
int group_node_first_index = 0;
int num_added_vectors_remaining = (int)num_added_vectors;
int batch_size = HNSW_BLOCKMAP_BLOCKS_PER_PAGE;
while(num_added_vectors_remaining > 0) {
StoreExternalIndexBlockMapGroup(index,
external_index,
Expand Down

0 comments on commit 57876ef

Please sign in to comment.