From: Richard Guenther Date: Tue, 25 Jan 2011 10:26:20 +0000 (+0000) Subject: re PR tree-optimization/47411 (Bootstrap failure on x86-64/Darwin) X-Git-Tag: releases/gcc-4.6.0~991 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=ae5b7e39b62c86ab13ad84a911d808f12e54a111;p=thirdparty%2Fgcc.git re PR tree-optimization/47411 (Bootstrap failure on x86-64/Darwin) 2011-01-25 Richard Guenther PR middle-end/47411 * gcc.dg/torture/pr47411.c: New testcase. From-SVN: r169225 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1b26d4a4aacf..f45aea88d841 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2011-01-25 Richard Guenther + + PR middle-end/47411 + * gcc.dg/torture/pr47411.c: New testcase. + 2011-01-25 Sebastian Pop * gfortran.dg/graphite/id-24.f: New. diff --git a/gcc/testsuite/gcc.dg/torture/pr47411.c b/gcc/testsuite/gcc.dg/torture/pr47411.c new file mode 100644 index 000000000000..d3c10d331e75 --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr47411.c @@ -0,0 +1,42 @@ +/* { dg-do compile } */ + +typedef long unsigned int size_t; + +static __inline void * +__inline_memcpy_chk (void *__dest, const void *__src, size_t __len) +{ + return __builtin___memcpy_chk (__dest, __src, __len, __builtin_object_size (__dest, 0)); +} + +extern void *xmalloc (size_t) __attribute__ ((__malloc__)); + +struct htab { void ** entries; }; + +typedef struct htab *htab_t; + +extern void ** htab_find_slot (htab_t, const void *); + +enum mode_class { MODE_RANDOM, MODE_CC, MODE_INT, MAX_MODE_CLASS }; + +struct mode_data +{ + struct mode_data *next; + enum mode_class cl; +}; + +static const struct mode_data blank_mode = { 0, MAX_MODE_CLASS }; + +static htab_t modes_by_name; + +struct mode_data * +new_mode (void) +{ + struct mode_data *m + = ((struct mode_data *) xmalloc (sizeof (struct mode_data))); + + ((__builtin_object_size (m, 0) != (size_t) -1) ? __builtin___memcpy_chk (m, &blank_mode, sizeof (struct mode_data), __builtin_object_size (m, 0)) : __inline_memcpy_chk (m, &blank_mode, sizeof (struct mode_data))); + + *htab_find_slot (modes_by_name, m) = m; + + return m; +}