From 29a3cb25d3e8db9ce9b42a68413c10c8551c4362 Mon Sep 17 00:00:00 2001 From: gingerBill Date: Tue, 7 Apr 2020 11:47:28 +0100 Subject: Add extra guards for window-only performance checking --- src/parser.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'src/parser.cpp') diff --git a/src/parser.cpp b/src/parser.cpp index 937e84279..b05f7df2f 100644 --- a/src/parser.cpp +++ b/src/parser.cpp @@ -442,15 +442,15 @@ bool ast_node_expect(Ast *node, AstKind kind) { } -gb_global isize volatile total_allocated_node_memory = 0; -gb_global isize volatile total_subtype_node_memory_test = 0; +gb_global gbAtomic64 total_allocated_node_memory = {0}; +gb_global gbAtomic64 total_subtype_node_memory_test = {0}; // NOTE(bill): And this below is why is I/we need a new language! Discriminated unions are a pain in C/C++ Ast *alloc_ast_node(AstFile *f, AstKind kind) { gbAllocator a = ast_allocator(); - _InterlockedExchangeAdd64(&total_allocated_node_memory, gb_size_of(Ast)); - _InterlockedExchangeAdd64(&total_subtype_node_memory_test, gb_size_of(AstCommonStuff) + ast_variant_sizes[kind]); + gb_atomic64_fetch_add(&total_allocated_node_memory, cast(i64)(gb_size_of(Ast))); + gb_atomic64_fetch_add(&total_subtype_node_memory_test, cast(i64)(gb_size_of(AstCommonStuff) + ast_variant_sizes[kind])); Ast *node = gb_alloc_item(a, Ast); node->kind = kind; -- cgit v1.2.3