aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2022-10-30 22:58:44 +0000
committergingerBill <bill@gingerbill.org>2022-10-30 22:58:44 +0000
commit8fa571c283dca207e9eae7b2924db3bbc9d6aa39 (patch)
tree805f03db4ae3dfd6de28a5b18a804fe357789c2c /src
parent83f3ae14d53bcc5fd16ace676535634e94fdf500 (diff)
Use direct parameter value in `lb_find_ident` when possible
Diffstat (limited to 'src')
-rw-r--r--src/llvm_backend.hpp1
-rw-r--r--src/llvm_backend_general.cpp9
-rw-r--r--src/llvm_backend_proc.cpp4
3 files changed, 14 insertions, 0 deletions
diff --git a/src/llvm_backend.hpp b/src/llvm_backend.hpp
index e69d3a6ed..8bd038c16 100644
--- a/src/llvm_backend.hpp
+++ b/src/llvm_backend.hpp
@@ -298,6 +298,7 @@ struct lbProcedure {
lbBlock * entry_block;
lbBlock * curr_block;
lbTargetList * target_list;
+ PtrMap<Entity *, lbValue> direct_parameters;
Ast *curr_stmt;
diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp
index 0dabee076..18cdd196d 100644
--- a/src/llvm_backend_general.cpp
+++ b/src/llvm_backend_general.cpp
@@ -2590,6 +2590,15 @@ lbValue lb_find_or_add_entity_string_byte_slice_with_type(lbModule *m, String co
lbValue lb_find_ident(lbProcedure *p, lbModule *m, Entity *e, Ast *expr) {
+ if (e->flags & EntityFlag_Param) {
+ // NOTE(bill): Bypass the stack copied variable for
+ // direct parameters as there is no need for the direct load
+ auto *found = map_get(&p->direct_parameters, e);
+ if (found) {
+ return *found;
+ }
+ }
+
auto *found = map_get(&m->values, e);
if (found) {
auto v = *found;
diff --git a/src/llvm_backend_proc.cpp b/src/llvm_backend_proc.cpp
index a88c8f2ee..2347c6bc0 100644
--- a/src/llvm_backend_proc.cpp
+++ b/src/llvm_backend_proc.cpp
@@ -486,6 +486,8 @@ void lb_begin_procedure_body(lbProcedure *p) {
p->entry_block = lb_create_block(p, "entry", true);
lb_start_block(p, p->entry_block);
+ map_init(&p->direct_parameters, heap_allocator());
+
GB_ASSERT(p->type != nullptr);
lb_ensure_abi_function_type(p->module, p);
@@ -539,6 +541,8 @@ void lb_begin_procedure_body(lbProcedure *p) {
param.value = value;
param.type = e->type;
+ map_set(&p->direct_parameters, e, param);
+
lbValue ptr = lb_address_from_load_or_generate_local(p, param);
GB_ASSERT(LLVMIsAAllocaInst(ptr.value));
lb_add_entity(p->module, e, ptr);