From e4994bb69bb5c5358b33aa794484ea5b619e5eee Mon Sep 17 00:00:00 2001 From: Tsukasa OI Date: Tue, 28 Jun 2022 19:07:52 +0900 Subject: [PATCH] RISC-V: Improve "bits undefined" diagnostics This commit improves internal error message "internal: bad RISC-V opcode (bits 0x%lx undefined): %s %s" to display actual unused bits (excluding non-instruction bits). gas/ChangeLog: * config/tc-riscv.c (validate_riscv_insn): Exclude non- instruction bits from displaying internal diagnostics. Change error message slightly. --- gas/config/tc-riscv.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gas/config/tc-riscv.c b/gas/config/tc-riscv.c index 291d07f6d8f..6db444b654f 100644 --- a/gas/config/tc-riscv.c +++ b/gas/config/tc-riscv.c @@ -1265,8 +1265,8 @@ validate_riscv_insn (const struct riscv_opcode *opc, int length) if (used_bits != required_bits) { as_bad (_("internal: bad RISC-V opcode " - "(bits 0x%lx undefined): %s %s"), - ~(unsigned long)(used_bits & required_bits), + "(bits 0x%lx undefined or invalid): %s %s"), + (unsigned long)(used_bits ^ required_bits), opc->name, opc->args); return false; }