diff options
| author | Andrew Kelley <andrew@ziglang.org> | 2020-07-24 14:06:44 -0700 |
|---|---|---|
| committer | Andrew Kelley <andrew@ziglang.org> | 2020-07-24 14:06:44 -0700 |
| commit | 995fd7314cd230ca7c829bb478f88b1ab7efd7b4 (patch) | |
| tree | 44566c0e999e8977a69d69f06fbfea8e4cc3ffd6 /src/ir.cpp | |
| parent | 978a38ee40e13c3eed625f2df7b36be49fd049e0 (diff) | |
| download | zig-995fd7314cd230ca7c829bb478f88b1ab7efd7b4.tar.gz zig-995fd7314cd230ca7c829bb478f88b1ab7efd7b4.zip | |
Revert "Support taking extern pointers at comptime"
This reverts commit d3ebd428650748e60db70dd2171cc044855814b1.
This caused a build failure on multiple targets.
Diffstat (limited to 'src/ir.cpp')
| -rw-r--r-- | src/ir.cpp | 61 |
1 files changed, 27 insertions, 34 deletions
diff --git a/src/ir.cpp b/src/ir.cpp index df5a0a47df..cf8558761f 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -19894,34 +19894,30 @@ static IrInstGen *ir_get_var_ptr(IrAnalyze *ira, IrInst *source_instr, ZigVar *v IrInstGen *result = ir_build_var_ptr_gen(ira, source_instr, var); result->value->type = var_ptr_type; - bool is_local_var = !var->decl_node->data.variable_declaration.is_extern && - var->const_value->special == ConstValSpecialRuntime; - - // The address of a thread-local variable can't be resolved even by a linker because - // it's dependent on the current thread. The concept of current thread doesn't exist - // at compile time, so even if we had a symbolic (i.e., relocatable) representation - // of a pointer to a thread-local variable, there would be no ways to make use of it - // in a meaningful way. - // - // The same goes for local variables - They are stored in a stack frame, whose - // instance doesn't even exist at compile/link time. - if (!var->is_thread_local && !is_local_var) { + if (!linkage_makes_it_runtime && !var->is_thread_local && value_is_comptime(var->const_value)) { ZigValue *val = var->const_value; - - ConstPtrMut ptr_mut; - if (comptime_var_mem) { - ptr_mut = ConstPtrMutComptimeVar; - } else if (var->gen_is_const && !linkage_makes_it_runtime) { - ptr_mut = ConstPtrMutComptimeConst; - } else { - assert(!comptime_var_mem); - ptr_mut = ConstPtrMutRuntimeVar; + switch (val->special) { + case ConstValSpecialRuntime: + break; + case ConstValSpecialStatic: // fallthrough + case ConstValSpecialLazy: // fallthrough + case ConstValSpecialUndef: { + ConstPtrMut ptr_mut; + if (comptime_var_mem) { + ptr_mut = ConstPtrMutComptimeVar; + } else if (var->gen_is_const) { + ptr_mut = ConstPtrMutComptimeConst; + } else { + assert(!comptime_var_mem); + ptr_mut = ConstPtrMutRuntimeVar; + } + result->value->special = ConstValSpecialStatic; + result->value->data.x_ptr.mut = ptr_mut; + result->value->data.x_ptr.special = ConstPtrSpecialRef; + result->value->data.x_ptr.data.ref.pointee = val; + return result; + } } - result->value->special = ConstValSpecialStatic; - result->value->data.x_ptr.mut = ptr_mut; - result->value->data.x_ptr.special = ConstPtrSpecialRef; - result->value->data.x_ptr.data.ref.pointee = val; - return result; } bool in_fn_scope = (scope_fn_entry(var->parent_scope) != nullptr); @@ -22292,15 +22288,12 @@ static IrInstGen *ir_analyze_struct_field_ptr(IrAnalyze *ira, IrInst* source_ins if (type_is_invalid(struct_val->type)) return ira->codegen->invalid_inst_gen; - if (ptr_val->data.x_ptr.mut != ConstPtrMutRuntimeVar) { - // This to allow lazy values to be resolved. - if ((err = ir_resolve_const_val(ira->codegen, ira->new_irb.exec, - source_instr->source_node, struct_val, UndefOk))) - { - return ira->codegen->invalid_inst_gen; - } + // This to allow lazy values to be resolved. + if ((err = ir_resolve_const_val(ira->codegen, ira->new_irb.exec, + source_instr->source_node, struct_val, UndefOk))) + { + return ira->codegen->invalid_inst_gen; } - if (initializing && struct_val->special == ConstValSpecialUndef) { struct_val->data.x_struct.fields = alloc_const_vals_ptrs(ira->codegen, struct_type->data.structure.src_field_count); struct_val->special = ConstValSpecialStatic; |
