]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
s390: Lower severity of assembler syntax errors from fatal to error
authorJens Remus <jremus@linux.ibm.com>
Fri, 1 Mar 2024 11:45:14 +0000 (12:45 +0100)
committerJens Remus <jremus@linux.ibm.com>
Fri, 1 Mar 2024 11:45:14 +0000 (12:45 +0100)
Report s390 assembler syntax errors as error instead of fatal error.
This allows the assembler to continue and potentially report further
syntax errors in the source. This should not cause syntax errors to
be erroneously accepted, as both error and fatal error cause the
assembler to return with a non-zero return code.

The following syntax errors are changed from fatal to error:
- invalid length field specified
- odd numbered general purpose register specified as register pair
- invalid floating point register pair.  Valid fp register pair operands
  are 0, 1, 4, 5, 8, 9, 12 or 13.

gas/
* config/tc-s390.c: Lower severity of assembler syntax errors
from fatal to error.
* testsuite/gas/s390/zarch-z9-109-err.l: Likewise.

Reviewed-by: Andreas Krebbel <krebbel@linux.ibm.com>
Signed-off-by: Jens Remus <jremus@linux.ibm.com>
gas/config/tc-s390.c
gas/testsuite/gas/s390/zarch-z9-109-err.l

index 09a903aea2db3ffc9a2f613b7e2349620c138aea..1b7935a848d00c6ef6270a7e44a2ac1eff25efc0 100644 (file)
@@ -1346,7 +1346,7 @@ md_gather_operands (char *str,
            {
              if ((operand->flags & S390_OPERAND_LENGTH)
                  && ex.X_op != O_constant)
-               as_fatal (_("invalid length field specified"));
+               as_bad (_("invalid length field specified"));
              if ((operand->flags & S390_OPERAND_INDEX)
                  && ex.X_add_number == 0
                  && warn_areg_zero)
@@ -1358,17 +1358,17 @@ md_gather_operands (char *str,
              if ((operand->flags & S390_OPERAND_GPR)
                  && (operand->flags & S390_OPERAND_REG_PAIR)
                  && (ex.X_add_number & 1))
-               as_fatal (_("odd numbered general purpose register specified as "
-                           "register pair"));
+               as_bad (_("odd numbered general purpose register specified as "
+                         "register pair"));
              if ((operand->flags & S390_OPERAND_FPR)
                  && (operand->flags & S390_OPERAND_REG_PAIR)
                  && ex.X_add_number != 0 && ex.X_add_number != 1
                  && ex.X_add_number != 4 && ex.X_add_number != 5
                  && ex.X_add_number != 8 && ex.X_add_number != 9
                  && ex.X_add_number != 12 && ex.X_add_number != 13)
-               as_fatal (_("invalid floating point register pair.  Valid fp "
-                           "register pair operands are 0, 1, 4, 5, 8, 9, "
-                           "12 or 13."));
+               as_bad (_("invalid floating point register pair.  Valid fp "
+                         "register pair operands are 0, 1, 4, 5, 8, 9, "
+                         "12 or 13."));
              s390_insert_operand (insn, operand, ex.X_add_number, NULL, 0);
            }
        }
index 1b06f93441a0f573e8a18b6c1b0ece8e79923f6e..84d294de960a3064422fc5140714b7b90dbd0be6 100644 (file)
@@ -1,2 +1,2 @@
 .*: Assembler messages:
-.*:3: Fatal error: odd numbered general purpose register specified as register pair
+.*:3: Error: odd numbered general purpose register specified as register pair