aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2024-02-22 19:24:50 +0000
committergingerBill <bill@gingerbill.org>2024-02-22 19:24:50 +0000
commite127d21fedbcd5600d8bd1faf2dec40f3767658e (patch)
tree70dba2b8c623fed59f7220539e9dfac2789ee250 /src/llvm_backend_expr.cpp
parent3060225f460cb5d1ad124fcf449b27b3e2e981f8 (diff)
Check for pseudo-fields before bit fields
Diffstat (limited to 'src/llvm_backend_expr.cpp')
-rw-r--r--src/llvm_backend_expr.cpp14
1 files changed, 8 insertions, 6 deletions
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp
index 442121f83..a6f4a5752 100644
--- a/src/llvm_backend_expr.cpp
+++ b/src/llvm_backend_expr.cpp
@@ -4677,6 +4677,13 @@ gb_internal lbAddr lb_build_addr_internal(lbProcedure *p, Ast *expr) {
Selection sel = lookup_field(type, selector, false);
GB_ASSERT(sel.entity != nullptr);
+ if (sel.pseudo_field) {
+ GB_ASSERT(sel.entity->kind == Entity_Procedure || sel.entity->kind == Entity_ProcGroup);
+ Entity *e = entity_of_node(sel_node);
+ GB_ASSERT(e->kind == Entity_Procedure);
+ return lb_addr(lb_find_value_from_entity(p->module, e));
+ }
+
if (sel.is_bit_field) {
lbAddr addr = lb_build_addr(p, se->expr);
@@ -4703,12 +4710,7 @@ gb_internal lbAddr lb_build_addr_internal(lbProcedure *p, Ast *expr) {
return lb_addr_bit_field(a, f->type, index, bit_offset, bit_size);
}
- if (sel.pseudo_field) {
- GB_ASSERT(sel.entity->kind == Entity_Procedure || sel.entity->kind == Entity_ProcGroup);
- Entity *e = entity_of_node(sel_node);
- GB_ASSERT(e->kind == Entity_Procedure);
- return lb_addr(lb_find_value_from_entity(p->module, e));
- }
+
{
lbAddr addr = lb_build_addr(p, se->expr);