Replace local @(no_red_zone) with global -disable-red-zone

This commit is contained in:
gingerBill
2022-02-23 11:29:36 +00:00
parent 493bc653b5
commit 196bd735d4
7 changed files with 17 additions and 18 deletions

View File

@@ -278,6 +278,7 @@ struct BuildContext {
bool copy_file_contents;
RelocMode reloc_mode;
bool disable_red_zone;
u32 cmd_doc_flags;
@@ -1002,6 +1003,13 @@ void init_build_context(TargetMetrics *cross_target) {
bc->threaded_checker = true;
#endif
if (bc->disable_red_zone) {
if (!(bc->metrics.os == TargetOs_freestanding && !is_arch_wasm())) {
gb_printf_err("-disable-red-zone is not support for this target");
gb_exit(1);
}
}
// NOTE(zangent): The linker flags to set the build architecture are different
// across OSs. It doesn't make sense to allocate extra data on the heap

View File

@@ -826,14 +826,6 @@ void check_proc_decl(CheckerContext *ctx, Entity *e, DeclInfo *d) {
}
e->Procedure.optimization_mode = cast(ProcedureOptimizationMode)ac.optimization_mode;
if (ac.no_red_zone) {
if (!is_arch_wasm()) {
e->Procedure.no_red_zone = true;
} else {
error(e->token, "@(no_red_zone) is not supported on this target architecture");
}
}
if (ac.objc_name.len || ac.objc_is_class_method || ac.objc_type) {
if (ac.objc_name.len == 0 && ac.objc_is_class_method) {
error(e->token, "@(objc_name) is required with @(objc_is_class_method)");

View File

@@ -3128,13 +3128,6 @@ DECL_ATTRIBUTE_PROC(proc_decl_attribute) {
}
}
return true;
} else if (name == "no_red_zone") {
if (value != nullptr) {
error(elem, "Expected no value for '%.*s'", LIT(name));
} else {
ac->no_red_zone = true;
}
return true;
}
return false;
}

View File

@@ -117,7 +117,6 @@ struct AttributeContext {
bool test : 1;
bool init : 1;
bool set_cold : 1;
bool no_red_zone : 1;
u32 optimization_mode; // ProcedureOptimizationMode
String objc_class;

View File

@@ -226,7 +226,6 @@ struct Entity {
bool is_foreign;
bool is_export;
bool generated_from_polymorphic;
bool no_red_zone;
ProcedureOptimizationMode optimization_mode;
} Procedure;
struct {

View File

@@ -135,7 +135,7 @@ lbProcedure *lb_create_procedure(lbModule *m, Entity *entity, bool ignore_body)
lb_add_attribute_to_proc(m, p->value, "naked");
}
if (entity->Procedure.no_red_zone) {
if (!entity->Procedure.is_foreign && build_context.disable_red_zone) {
lb_add_attribute_to_proc(m, p->value, "noredzone");
}

View File

@@ -626,6 +626,7 @@ enum BuildFlagKind {
BuildFlag_Microarch,
BuildFlag_RelocMode,
BuildFlag_DisableRedZone,
BuildFlag_TestName,
@@ -782,6 +783,7 @@ bool parse_build_flags(Array<String> args) {
add_flag(&build_flags, BuildFlag_Microarch, str_lit("microarch"), BuildFlagParam_String, Command__does_build);
add_flag(&build_flags, BuildFlag_RelocMode, str_lit("reloc-mode"), BuildFlagParam_String, Command__does_build);
add_flag(&build_flags, BuildFlag_DisableRedZone, str_lit("disable-red-zone"), BuildFlagParam_None, Command__does_build);
add_flag(&build_flags, BuildFlag_TestName, str_lit("test-name"), BuildFlagParam_String, Command_test);
@@ -1365,6 +1367,9 @@ bool parse_build_flags(Array<String> args) {
break;
}
case BuildFlag_DisableRedZone:
build_context.disable_red_zone = true;
break;
case BuildFlag_TestName: {
GB_ASSERT(value.kind == ExactValue_String);
{
@@ -2096,6 +2101,9 @@ void print_show_help(String const arg0, String const &command) {
print_usage_line(3, "pic");
print_usage_line(3, "dynamic-no-pic");
print_usage_line(0, "");
print_usage_line(1, "-disable-red-zone");
print_usage_line(2, "Disable red zone on a supported freestanding target");
}
if (check) {