]> git.lizzy.rs Git - rust.git/commitdiff
Disallow a form of invalid asm! macro
authorSimonas Kazlauskas <git@kazlauskas.me>
Wed, 14 Jan 2015 15:02:20 +0000 (17:02 +0200)
committerSimonas Kazlauskas <git@kazlauskas.me>
Wed, 14 Jan 2015 15:03:03 +0000 (17:03 +0200)
Fixes #21045

src/libsyntax/ext/asm.rs
src/test/compile-fail/issue-21045.rs [new file with mode: 0644]

index fd3bac5b2fc7bce38d0304d2880e1e685593f6b3..4258eb32fdf0f671b47295596944f12a8f20d567 100644 (file)
@@ -63,6 +63,12 @@ pub fn expand_asm<'cx>(cx: &'cx mut ExtCtxt, sp: Span, tts: &[ast::TokenTree])
     'statement: loop {
         match state {
             Asm => {
+                if asm_str_style.is_some() {
+                    // If we already have a string with instructions,
+                    // ending up in Asm state again is an error.
+                    cx.span_err(sp, "malformed inline assembly");
+                    return DummyResult::expr(sp);
+                }
                 let (s, style) = match expr_to_string(cx, p.parse_expr(),
                                                    "inline assembly must be a string literal") {
                     Some((s, st)) => (s, st),
diff --git a/src/test/compile-fail/issue-21045.rs b/src/test/compile-fail/issue-21045.rs
new file mode 100644 (file)
index 0000000..134240f
--- /dev/null
@@ -0,0 +1,16 @@
+// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+#![feature(asm)]
+
+fn main() {
+    let a;
+    asm!("nop" "nop"); //~ ERROR malformed inline assembly
+    asm!("nop" "nop" : "=r"(a)); //~ ERROR malformed inline assembly
+}