summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/pr27531-1.c
diff options
context:
space:
mode:
authorupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
committerupstream source tree <ports@midipix.org>2015-03-15 20:14:05 -0400
commit554fd8c5195424bdbcabf5de30fdc183aba391bd (patch)
tree976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/gcc.dg/pr27531-1.c
downloadcbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.bz2
cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.xz
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
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.
Diffstat (limited to 'gcc/testsuite/gcc.dg/pr27531-1.c')
-rw-r--r--gcc/testsuite/gcc.dg/pr27531-1.c114
1 files changed, 114 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/pr27531-1.c b/gcc/testsuite/gcc.dg/pr27531-1.c
new file mode 100644
index 000000000..08e3f5ea2
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr27531-1.c
@@ -0,0 +1,114 @@
+/* PR target/27531 */
+/* This test case stressed the register allocator into reloading a LABEL_REF
+ on sparc, but didn't add a REG_LABEL note, ultimately causing the assembly
+ output to reference a label that had been eliminated. */
+/* { dg-do link } */
+/* { dg-options "-O2" } */
+typedef struct _IO_FILE FILE;
+char const *RCSname;
+void *Locks;
+void * Head;
+struct Revpairs{
+ struct Revpairs * rnext;
+};
+extern char *strchr(const char *s, int c);
+extern int fprintf(FILE *, const char *format, ...);
+static void getrevpairs (char*);
+static int branchflag;
+static struct Revpairs *revlist, *Revlst;
+
+extern int warn(const char *msg, char *argv);
+extern int error(const char *msg, int c, char *argv);
+extern int recentdate(void *foo, void *bar);
+
+char *t;
+int main (int argc, char **argv)
+{
+ FILE *out;
+ char *a, **newargv;
+ void *currdate;
+ int descflag, selectflag;
+ int onlylockflag;
+ int onlyRCSflag;
+ int shownames;
+ descflag = selectflag = shownames = 1;
+ onlylockflag = onlyRCSflag = 0;
+ while (a = *++argv, 0<--argc)
+ {
+ switch (*a++)
+ {
+ case 'L':
+ onlylockflag = 1;
+ case 'N':
+ shownames = 0;
+ case 'R':
+ t = a;
+ case 'b':
+ branchflag = 1;
+ case 'r':
+ getrevpairs(a);
+ }
+ if (onlylockflag && !Locks)
+ fprintf(out, "%s\n", RCSname);
+ if (shownames)
+ while( currdate)
+ recentdate(Head, currdate);
+ }
+}
+void getrevpairs(char *argv)
+{
+ char c;
+ struct Revpairs * nextrevpair;
+ int separator;
+ if (strchr(argv,':'))
+ separator = ':';
+ else
+ {
+ if (strchr(argv,'-') )
+ warn("`-' is obsolete in `-r%s'; use `:' instead", argv);
+ separator = '-';
+ }
+ for (;;)
+ {
+ nextrevpair->rnext = revlist;
+ for (;; c = *++argv)
+ {
+ switch (c)
+ {
+ default:
+ continue;
+ case ' ':
+ case '\t':
+ case '\n':
+ break;
+ case ':':
+ case '-':
+ if (c == separator)
+ continue;
+ }
+ break;
+ }
+ if (!c)
+ break;
+ error("missing `,' near `%c%s'", c, argv+1);
+ }
+}
+
+int warn(const char *msg, char *argv)
+{
+ t = 0; /* this function needs side-effects. */
+ return 0;
+}
+
+int error(const char *msg, int c, char *argv)
+{
+ t = 0; /* this function needs side-effects. */
+ return 0;
+}
+
+int recentdate(void *foo, void *bar)
+{
+ t = 0; /* this function needs side-effects. */
+ return 0;
+}
+