]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
gas: don't permit "repeat" expressions with .cfi_{escape,fde_data}
authorJan Beulich <jbeulich@suse.com>
Fri, 7 Mar 2025 10:27:58 +0000 (11:27 +0100)
committerJan Beulich <jbeulich@suse.com>
Fri, 7 Mar 2025 10:27:58 +0000 (11:27 +0100)
Repeat counts greater than 1 will emit data directly into the current
(sub-)section. That's wrong with .cfi_*, which defer data emission until
much later: N-1 instances of the specified data would not end up in
.eh_frame (or whatever the section that CFI data was specified to go
into). Simply disallow "repeat" expressions in such cases.

gas/read.c

index 171182d5a0f6a9595362f523c3b5e13e58c943fc..12b6d3029a6a33c5612f190be64d335d3c6af239 100644 (file)
@@ -4179,6 +4179,20 @@ static void
 parse_mri_cons (expressionS *exp, unsigned int nbytes);
 #endif
 
+/* This function is used by .cfi_* directive handling, and hence must not
+   invoke parse_repeat_cons().  */
+
+void
+do_parse_cons_expression (expressionS *exp,
+                         int nbytes ATTRIBUTE_UNUSED)
+{
+#ifdef TC_PARSE_CONS_EXPRESSION
+  (void) TC_PARSE_CONS_EXPRESSION (exp, nbytes);
+#else
+  expression (exp);
+#endif
+}
+
 #ifndef TC_PARSE_CONS_EXPRESSION
 #ifdef REPEAT_CONS_EXPRESSIONS
 #define TC_PARSE_CONS_EXPRESSION(EXP, NBYTES) \
@@ -4194,14 +4208,6 @@ parse_repeat_cons (expressionS *exp, unsigned int nbytes);
 #endif
 #endif
 
-void
-do_parse_cons_expression (expressionS *exp,
-                         int nbytes ATTRIBUTE_UNUSED)
-{
-  (void) TC_PARSE_CONS_EXPRESSION (exp, nbytes);
-}
-
-
 /* Worker to do .byte etc statements.
    Clobbers input_line_pointer and checks end-of-line.  */