From: jjasmine <tanghocle...@gmail.com>

gcc/rust/ChangeLog:

        * expand/rust-macro-builtins-asm.cc (parse_reg_operand):
        Fix compile warnings.
        (parse_options): Likewise.
        (parse_asm): Likewise.

gcc/testsuite/ChangeLog:

        * rust/compile/inline_asm_illegal_options.rs:
---
 gcc/rust/expand/rust-macro-builtins-asm.cc             | 10 +++++++---
 .../rust/compile/inline_asm_illegal_options.rs         |  3 +++
 2 files changed, 10 insertions(+), 3 deletions(-)

diff --git a/gcc/rust/expand/rust-macro-builtins-asm.cc 
b/gcc/rust/expand/rust-macro-builtins-asm.cc
index dd053df04b2..95a268a02de 100644
--- a/gcc/rust/expand/rust-macro-builtins-asm.cc
+++ b/gcc/rust/expand/rust-macro-builtins-asm.cc
@@ -219,7 +219,6 @@ parse_reg_operand (Parser<MacroInvocLexer> &parser, TokenId 
last_token_id,
 
   token = parser.peek_current_token ();
 
-  bool is_explicit_reg = false;
   bool is_global_asm = inline_asm.is_global_asm;
   if (!is_global_asm && check_identifier (parser, "in"))
     {
@@ -354,7 +353,12 @@ parse_options (Parser<MacroInvocLexer> &parser, TokenId 
last_token_id,
        {
          // TODO: Unexpected error, please return the correct error
          rust_error_at (token->get_locus (),
-                        "Unexpected token encountered in parse_options");
+                        "expected one of %qs, %qs, %qs, %qs, %qs, %qs, %qs, "
+                        "%qs, %qs, or %qs, found %qs",
+                        ")", "att_syntax", "may_unwind", "nomem", "noreturn",
+                        "nostack", "preserves_flags", "pure", "raw",
+                        "readonly", token->as_string ().c_str ());
+         return -1;
        }
       if (parser.skip_token (RIGHT_PAREN))
        {
@@ -519,7 +523,7 @@ parse_asm (location_t invoc_locus, AST::MacroInvocData 
&invoc,
   if (fm_string == tl::nullopt)
     {
       rust_error_at (parser.peek_current_token ()->get_locus (),
-                    "asm template must be a string literal");
+                    "%s template must be a string literal", "asm");
       return tl::nullopt;
     }
 
diff --git a/gcc/testsuite/rust/compile/inline_asm_illegal_options.rs 
b/gcc/testsuite/rust/compile/inline_asm_illegal_options.rs
index bf34c4489f1..2cf354d6d12 100644
--- a/gcc/testsuite/rust/compile/inline_asm_illegal_options.rs
+++ b/gcc/testsuite/rust/compile/inline_asm_illegal_options.rs
@@ -9,5 +9,8 @@ fn main() {
     unsafe {
         asm!("nop", options(nomem, nomem)); // { dg-error "the 'nomem' option 
was already provided" }
         asm!("nop", options(noreturn, noreturn)); // { dg-error "the 
'noreturn' option was already provided" }
+        asm!("nop", options(xxx)); // { dg-error "expected one of '\\)', 
'att_syntax', 'may_unwind', 'nomem', 'noreturn', 'nostack', 'preserves_flags', 
'pure', 'raw', or 'readonly', found 'xxx'" }
+        asm!("nop", options(+)); // { dg-error "expected one of '\\)', 
'att_syntax', 'may_unwind', 'nomem', 'noreturn', 'nostack', 'preserves_flags', 
'pure', 'raw', or 'readonly', found '\\+'" }
+
     }
 }
\ No newline at end of file
-- 
2.45.2

Reply via email to