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/gcc.dg/pr27531-1.c | 114 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 114 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/pr27531-1.c (limited to 'gcc/testsuite/gcc.dg/pr27531-1.c') 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; +} + -- cgit v1.2.3