From: Jakub Jelinek Date: Fri, 21 May 2010 18:45:29 +0000 (+0200) Subject: re PR debug/44223 (segmentation fault with -g -fsched-pressure) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=14db98d4a6349271ab34e894c9b0780cb985666b;p=gcc.git re PR debug/44223 (segmentation fault with -g -fsched-pressure) PR debug/44223 * haifa-sched.c (schedule_insn): When freeing INSN_REG_USE_LIST, unchain each use from the cyclic next_regno_use chain first. * gcc.target/i386/pr44223.c: New test. From-SVN: r159680 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ee78f2340d8..dcfff779fc1 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-05-21 Jakub Jelinek + + PR debug/44223 + * haifa-sched.c (schedule_insn): When freeing INSN_REG_USE_LIST, + unchain each use from the cyclic next_regno_use chain first. + 2010-05-21 Steven Bosscher * real: Do not include gmp.h, mpfr.h, and mpc.h. diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c index f7c087fef79..b15fe63f34a 100644 --- a/gcc/haifa-sched.c +++ b/gcc/haifa-sched.c @@ -1721,6 +1721,12 @@ schedule_insn (rtx insn) /* Unknown location doesn't use any registers. */ for (use = INSN_REG_USE_LIST (dbg); use != NULL; use = next) { + struct reg_use_data *prev = use; + + /* Remove use from the cyclic next_regno_use chain first. */ + while (prev->next_regno_use != use) + prev = prev->next_regno_use; + prev->next_regno_use = use->next_regno_use; next = use->next_insn_use; free (use); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 259ee77b691..d40fc045d2d 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-05-21 Jakub Jelinek + + PR debug/44223 + * gcc.target/i386/pr44223.c: New test. + 2010-05-21 Rainer Orth * gcc.target/i386/pr25993.c: Use @function as type specifier. diff --git a/gcc/testsuite/gcc.target/i386/pr44223.c b/gcc/testsuite/gcc.target/i386/pr44223.c new file mode 100644 index 00000000000..3b8030c1bbb --- /dev/null +++ b/gcc/testsuite/gcc.target/i386/pr44223.c @@ -0,0 +1,36 @@ +/* PR debug/44223 */ +/* { dg-do compile } */ +/* { dg-options "-O3 -fsched-pressure -fschedule-insns -fpic -march=core2 -g" { target fpic } } */ + +struct S { unsigned int s1; int s2; }; +struct T { int t; }; + +extern void extfn (struct S *); + +static inline void +foo (struct S *s, unsigned char *x, int y) +{ + s->s2 = 32; +} + +static inline void +bar (struct S *s, int n, unsigned int x) +{ + unsigned int s1; + int s2; + s1 = s->s1; + s2 = s->s2; + if (n < s2) + s1 = (s1 << n) | x; + s->s1 = s1; +} + +int +baz (struct T *u, unsigned char *v, int w) +{ + struct S y; + foo (&y, v, 7); + bar (&y, 12, 0xfff); + bar (&y, 2, u->t); + extfn (&y); +}