0
0
mirror of https://github.com/netwide-assembler/nasm.git synced 2025-09-22 10:43:39 -04:00

warnings: make it possible for a warning to default to an error

This allows us to do soft-migration of warnings to errors; they will
now be nonfatal errors by default, but gives the user the option to
demote them.

Signed-off-by: H. Peter Anvin (Intel) <hpa@zytor.com>
This commit is contained in:
H. Peter Anvin (Intel)
2018-12-12 16:11:08 -08:00
parent 93367ea97b
commit eb48c1191d
3 changed files with 40 additions and 38 deletions

View File

@@ -46,34 +46,38 @@
* Description of the suppressible warnings for the command line and * Description of the suppressible warnings for the command line and
* the [warning] directive. * the [warning] directive.
*/ */
#define on (WARN_ST_ENABLED)
#define off 0
#define err (WARN_ST_ENABLED|WARN_ST_ERROR)
const struct warning warnings[WARN_ALL+1] = { const struct warning warnings[WARN_ALL+1] = {
{NULL, NULL, true}, /* must be true - used for unconditional enable */ {NULL, NULL, on}, /* must be on - used for unconditional enable */
{"macro-params", "macro calls with wrong parameter count", true}, {"macro-params", "macro calls with wrong parameter count", on},
{"macro-selfref", "cyclic macro references", false}, {"macro-selfref", "cyclic macro references", off},
{"macro-defaults", "macros with more default than optional parameters", true}, {"macro-defaults", "macros with more default than optional parameters", on},
{"orphan-labels", "labels alone on lines without trailing `:'", true}, {"orphan-labels", "labels alone on lines without trailing `:'", on},
{"number-overflow", "numeric constant does not fit", true}, {"number-overflow", "numeric constant does not fit", on},
{"gnu-elf-extensions", "using 8- or 16-bit relocation in ELF32, a GNU extension", false}, {"gnu-elf-extensions", "using 8- or 16-bit relocation in ELF32, a GNU extension", off},
{"float-overflow", "floating point overflow", true}, {"float-overflow", "floating point overflow", on},
{"float-denorm", "floating point denormal", false}, {"float-denorm", "floating point denormal", off},
{"float-underflow", "floating point underflow", false}, {"float-underflow", "floating point underflow", off},
{"float-toolong", "too many digits in floating-point number", true}, {"float-toolong", "too many digits in floating-point number", on},
{"user", "%warning directives", true}, {"user", "%warning directives", on},
{"lock", "lock prefix on unlockable instructions", true}, {"lock", "lock prefix on unlockable instructions", on},
{"hle", "invalid hle prefixes", true}, {"hle", "invalid hle prefixes", on},
{"bnd", "invalid bnd prefixes", true}, {"bnd", "invalid bnd prefixes", on},
{"zext-reloc", "relocation zero-extended to match output format", true}, {"zext-reloc", "relocation zero-extended to match output format", on},
{"ptr", "non-NASM keyword used in other assemblers", true}, {"ptr", "non-NASM keyword used in other assemblers", on},
{"bad-pragma", "empty or malformed %pragma", false}, {"bad-pragma", "empty or malformed %pragma", off},
{"unknown-pragma", "unknown %pragma facility or directive", false}, {"unknown-pragma", "unknown %pragma facility or directive", off},
{"not-my-pragma", "%pragma not applicable to this compilation", false}, {"not-my-pragma", "%pragma not applicable to this compilation", off},
{"unknown-warning", "unknown warning in -W/-w or warning directive", false}, {"unknown-warning", "unknown warning in -W/-w or warning directive", off},
{"negative-rep", "regative %rep count", true}, {"negative-rep", "regative %rep count", on},
{"phase", "phase error during stabilization", false}, {"phase", "phase error during stabilization", off},
/* THESE ENTRIES SHOULD COME LAST */ /* THESE ENTRIES SHOULD COME LAST */
{"other", "any warning not specifially mentioned below", true}, {"other", "any warning not specifially mentioned below", on},
{"all", "all possible warnings", false} {"all", "all possible warnings", off}
}; };
uint8_t warning_state[WARN_ALL];/* Current state */ uint8_t warning_state[WARN_ALL];/* Current state */
@@ -120,7 +124,7 @@ fatal_func nasm_assert_failed(const char *file, int line, const char *msg)
/* /*
* This is called when processing a -w or -W option, or a warning directive. * This is called when processing a -w or -W option, or a warning directive.
* Returns true if if the action was successful. * Returns on if if the action was successful.
*/ */
bool set_warning_status(const char *value) bool set_warning_status(const char *value)
{ {

View File

@@ -1346,10 +1346,8 @@ static void parse_cmdline(int argc, char **argv, int pass)
* Initialize all the warnings to their default state, including * Initialize all the warnings to their default state, including
* warning index 0 used for "always on". * warning index 0 used for "always on".
*/ */
for (i = 0; i < WARN_ALL; i++) { for (i = 0; i < WARN_ALL; i++)
warning_state_init[i] = warning_state[i] = warning_state_init[i] = warning_state[i] = warnings[i].state;
warnings[i].enabled ? WARN_ST_ENABLED : 0;
}
/* /*
* First, process the NASMENV environment variable. * First, process the NASMENV environment variable.
@@ -2059,7 +2057,8 @@ static void help(const char xopt)
printf(" %-23s %s%s\n", printf(" %-23s %s%s\n",
warnings[i].name, warnings[i].help, warnings[i].name, warnings[i].help,
i == WARN_ALL ? "\n" : i == WARN_ALL ? "\n" :
warnings[i].enabled ? " [on]" : " [off]"); (warnings[i].state & WARN_ST_ERROR) ? " [error]" :
(warnings[i].state & WARN_ST_ENABLED) ? " [on]" : " [off]");
if (xopt == 'f') { if (xopt == 'f') {
printf("valid output formats for -f are" printf("valid output formats for -f are"

View File

@@ -120,17 +120,16 @@ static inline vefunc nasm_set_verror(vefunc ve)
#define WARN_ALL (22+2) /* Do not use WARN() here */ #define WARN_ALL (22+2) /* Do not use WARN() here */
#define WARN_OTHER WARN(WARN_ALL-1) /* any noncategorized warning */ #define WARN_OTHER WARN(WARN_ALL-1) /* any noncategorized warning */
struct warning {
const char *name;
const char *help;
bool enabled;
};
extern const struct warning warnings[WARN_ALL+1];
/* This is a bitmask */ /* This is a bitmask */
#define WARN_ST_ENABLED 1 /* Warning is currently enabled */ #define WARN_ST_ENABLED 1 /* Warning is currently enabled */
#define WARN_ST_ERROR 2 /* Treat this warning as an error */ #define WARN_ST_ERROR 2 /* Treat this warning as an error */
struct warning {
const char *name;
const char *help;
uint8_t state; /* Default state for this warning */
};
extern const struct warning warnings[WARN_ALL+1];
extern uint8_t warning_state[WARN_ALL]; extern uint8_t warning_state[WARN_ALL];
extern uint8_t warning_state_init[WARN_ALL]; extern uint8_t warning_state_init[WARN_ALL];