From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- gcc/testsuite/g++.dg/ext/asmspecValid.C | 43 +++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 gcc/testsuite/g++.dg/ext/asmspecValid.C (limited to 'gcc/testsuite/g++.dg/ext/asmspecValid.C') diff --git a/gcc/testsuite/g++.dg/ext/asmspecValid.C b/gcc/testsuite/g++.dg/ext/asmspecValid.C new file mode 100644 index 000000000..98d98b46f --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/asmspecValid.C @@ -0,0 +1,43 @@ +// tests that the asm directive is correctly handled for static fields +// in structures and classes. This only applies to C++; such +// directives generate errors in C. Assembler directives for local +// variables should be tested by the C test suite. +// +// Contributed by Robert Bowdidge (bowdidge@apple.com) 14 Oct 2003 + +// { dg-do compile } + +struct Foo { + // This should reference a variable called bar + static int i __asm__("bar"); +}; + + +class Bar { +public: + static int i __asm__("theRealI"); + static int j __asm__("theRealJ"); + int boof; +}; + +class Baz : public Bar { +public: + static char *ptr __asm__ ("theRealString"); +}; + +int main (int argc, char **argv) { + struct Foo myFoo; + Bar b; + myFoo.i = 1; + Foo::i = 2; + Baz::j = 10; + Baz::ptr = 0; + b.i = 1; + return (b.i); +} + + +/* { dg-final {scan-assembler "bar"} } */ +/* { dg-final {scan-assembler "theRealString"} } */ +/* { dg-final {scan-assembler "theRealI" } } */ +/* { dg-final {scan-assembler "theRealJ" } } */ -- cgit v1.2.3