]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
fix typo in attr_fnspec::verify
authorAlexandre Oliva <oliva@adacore.com>
Wed, 14 Jul 2021 01:25:56 +0000 (22:25 -0300)
committerAlexandre Oliva <oliva@gnu.org>
Wed, 14 Jul 2021 01:28:25 +0000 (22:28 -0300)
Odd-numbered indices describing argument access sizes in the fnspec
string can only hold 't' or a digit, as tested in the beginning of the
case.  When checking that the size-supplying argument does not have
additional information associated with it, the test that excludes the
't' possibility looks for it at the even position in the fnspec
string.  Oops.

This might yield false positives and negatives if a function has a
fnspec in which an argument uses a 't' access-size, and ('t' - '1')
happens to be the index of an argument described in an fnspec string.
Assuming ASCII encoding, it would take a function with at least 68
arguments described in fnspec.  Still, probably worth fixing.

for  gcc/ChangeLog

* tree-ssa-alias.c (attr_fnspec::verify): Fix index in
non-'t'-sized arg check.

gcc/tree-ssa-alias.c

index 0421bfac9986982899bfa71ead8e05514b462130..742a95a549e200efcb5ca2abc9b7b5ce4f08e51a 100644 (file)
@@ -3895,7 +3895,7 @@ attr_fnspec::verify ()
                    && str[idx] != 'w' && str[idx] != 'W'
                    && str[idx] != 'o' && str[idx] != 'O')
                  err = true;
-               if (str[idx] != 't'
+               if (str[idx + 1] != 't'
                    /* Size specified is scalar, so it should be described
                       by ". " if specified at all.  */
                    && (arg_specified_p (str[idx + 1] - '1')