re PR c++/67064 (Register asm variable broken)
authorJason Merrill <jason@redhat.com>
Tue, 20 Oct 2015 06:49:13 +0000 (02:49 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Tue, 20 Oct 2015 06:49:13 +0000 (02:49 -0400)
PR c++/67064

* semantics.c (force_paren_expr): Don't mess with hard register vars.

From-SVN: r229021

gcc/cp/ChangeLog
gcc/cp/semantics.c
gcc/testsuite/g++.dg/parse/parens3.C [new file with mode: 0644]

index 842426b5f2d46f01ea4ebe4e478551695554542a..6ffa733c0ac053c99584e4930ec19f646053eb7e 100644 (file)
@@ -1,5 +1,8 @@
 2015-10-19  Jason Merrill  <jason@redhat.com>
 
+       PR c++/67064
+       * semantics.c (force_paren_expr): Don't mess with hard register vars.
+
        Implement N4268, Do constant evaluation of all non-type template args.
        * parser.c (cp_parser_template_argument): For C++1z just parse a
        constant-expression.
index 8796b176c15ac6cf785f43c8dbb9f2a37840db74..c0a8b32276782a902b4ee05e8709fde063ec12a8 100644 (file)
@@ -1660,6 +1660,8 @@ force_paren_expr (tree expr)
     REF_PARENTHESIZED_P (expr) = true;
   else if (type_dependent_expression_p (expr))
     expr = build1 (PAREN_EXPR, TREE_TYPE (expr), expr);
+  else if (VAR_P (expr) && DECL_HARD_REGISTER (expr))
+    /* We can't bind a hard register variable to a reference.  */;
   else
     {
       cp_lvalue_kind kind = lvalue_kind (expr);
diff --git a/gcc/testsuite/g++.dg/parse/parens3.C b/gcc/testsuite/g++.dg/parse/parens3.C
new file mode 100644 (file)
index 0000000..afb392b
--- /dev/null
@@ -0,0 +1,18 @@
+// PR c++/67064
+// { dg-options "-w" }
+
+struct s {
+  int i;
+};
+
+register struct s *reg __asm__( "1" );
+
+int f(void)
+{
+  int i;
+
+  i = reg->i;
+  i = (reg)->i;
+
+  return i;
+}