This is the mail archive of the gcc@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: 990208-1.c / our backend


On Thu, Sep 19, 2013 at 3:03 PM, Hendrik Greving
<hendrik.greving.intel@gmail.com> wrote:
> Hi,
>
> I have a GCC regression test failing for our backend for -O3. I am
> posting its code below. This might be more of a C-standard question,
> but is the optimization case guaranteed not to fail from a C
> perspective? When compiling it with our backend, the 'here' labels
> actually match.
>
>
> /* As a quality of implementation issue, we should not prevent inlining
>    of function explicitly marked inline just because a label therein had
>    its address taken.  */
>
> #ifndef NO_LABEL_VALUES
> static void *ptr1, *ptr2;
> static int i = 1;
>
> static __inline__ void doit(void **pptr, int cond)
> {
>   if (cond) {
>   here:
>     *pptr = &&here;
>   }
> }
>
> static void f(int cond)
> {
>   doit (&ptr1, cond);
> }
>
> static void g(int cond)
> {
>   doit (&ptr2, cond);
> }
>
> static void bar(void);
>
> int main()
> {
>   f (i);
>   bar();
>   g (i);
>
> #ifdef  __OPTIMIZE__
>   if (ptr1 == ptr2)
>     abort ();
> #endif
>
>   exit (0);
> }
>
> void bar(void) { }
>
> #else /* NO_LABEL_VALUES */
> int main() { exit(0); }
> #endif

It also failed on trunk with -O2/-O3 on x86.  But 990208-1.c has
been changed to

__attribute__ ((noinline))
static void f(int cond)
{
  doit (&ptr1, cond);
}

__attribute__ ((noinline))
static void g(int cond)
{
  doit (&ptr2, cond);
}

__attribute__ ((noinline))
static void bar(void);


-- 
H.J.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]