aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gas/ChangeLog7
-rw-r--r--gas/config/tc-i386.c40
-rw-r--r--gas/testsuite/gas/i386/quoted.d2
-rw-r--r--gas/testsuite/gas/i386/quoted.s2
4 files changed, 43 insertions, 8 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index f490eef..e4cf2af 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,5 +1,12 @@
2021-06-07 Jan Beulich <jbeulich@suse.com>
+ * config/tc-i386.c (i386_att_operand): Re-write handling of
+ vector operations operand suffix.
+ * testsuite/gas/i386/unary.s: Add more cases.
+ * testsuite/gas/i386/unary.d: Adjust expectations.
+
+2021-06-07 Jan Beulich <jbeulich@suse.com>
+
* config/tc-i386.c (parse_operands): Reduce scope of
paren_not_balanced, to match the new in_quotes. Skip over quoted
regions of operands.
diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c
index c838823..a874968 100644
--- a/gas/config/tc-i386.c
+++ b/gas/config/tc-i386.c
@@ -11488,7 +11488,6 @@ i386_att_operand (char *operand_string)
/* Start and end of displacement string expression (if found). */
char *displacement_string_start;
char *displacement_string_end;
- char *vop_start;
do_memory_reference:
if (i.mem_operands == 1 && !maybe_adjust_templates ())
@@ -11509,18 +11508,43 @@ i386_att_operand (char *operand_string)
base_string = op_string + strlen (op_string);
/* Handle vector operations. */
- vop_start = strchr (op_string, '{');
- if (vop_start && vop_start < base_string)
+ --base_string;
+ if (is_space_char (*base_string))
+ --base_string;
+
+ if (*base_string == '}')
{
+ char *vop_start = NULL;
+
+ while (base_string-- > op_string)
+ {
+ if (*base_string == '"')
+ break;
+ if (*base_string != '{')
+ continue;
+
+ vop_start = base_string;
+
+ --base_string;
+ if (is_space_char (*base_string))
+ --base_string;
+
+ if (*base_string != '}')
+ break;
+
+ vop_start = NULL;
+ }
+
+ if (!vop_start)
+ {
+ as_bad (_("unbalanced figure braces"));
+ return 0;
+ }
+
if (check_VecOperations (vop_start) == NULL)
return 0;
- base_string = vop_start;
}
- --base_string;
- if (is_space_char (*base_string))
- --base_string;
-
/* If we only have a displacement, set-up for it to be parsed later. */
displacement_string_start = op_string;
displacement_string_end = base_string + 1;
diff --git a/gas/testsuite/gas/i386/quoted.d b/gas/testsuite/gas/i386/quoted.d
index 11b28c0..c73576a 100644
--- a/gas/testsuite/gas/i386/quoted.d
+++ b/gas/testsuite/gas/i386/quoted.d
@@ -13,6 +13,8 @@ Disassembly of section .text:
[ ]*[a-f0-9]+:[ ]*a1 00 00 00 00[ ]+mov 0x0,%eax [a-f0-9]+: (R_386_|dir)32 x\(y
[ ]*[a-f0-9]+:[ ]*a1 00 00 00 00[ ]+mov 0x0,%eax [a-f0-9]+: (R_386_|dir)32 x\)y
[ ]*[a-f0-9]+:[ ]*a1 00 00 00 00[ ]+mov 0x0,%eax [a-f0-9]+: (R_386_|dir)32 x\?y
+[ ]*[a-f0-9]+:[ ]*a1 00 00 00 00[ ]+mov 0x0,%eax [a-f0-9]+: (R_386_|dir)32 x\{y
+[ ]*[a-f0-9]+:[ ]*a1 00 00 00 00[ ]+mov 0x0,%eax [a-f0-9]+: (R_386_|dir)32 x\{z\}
[ ]*[a-f0-9]+:[ ]*ff 15 00 00 00 00[ ]+call \*0x0 [a-f0-9]+: (R_386_|dir)32 x\(y\)
[ ]*[a-f0-9]+:[ ]*26 ff 15 00 00 00 00[ ]+call \*%es:0x0 [a-f0-9]+: (R_386_|dir)32 x\(y\)
[ ]*[a-f0-9]+:[ ]*26 ff 15 00 00 00 00[ ]+call \*%es:0x0 [a-f0-9]+: (R_386_|dir)32 x\(y\)
diff --git a/gas/testsuite/gas/i386/quoted.s b/gas/testsuite/gas/i386/quoted.s
index 1e57c86..21ada46 100644
--- a/gas/testsuite/gas/i386/quoted.s
+++ b/gas/testsuite/gas/i386/quoted.s
@@ -8,6 +8,8 @@ quoted:
mov "x(y", %eax
mov "x)y", %eax
mov "x?y", %eax
+ mov "x{y", %eax
+ mov "x{z}", %eax
call *"x(y)"
call *%es:"x(y)"