blob: 37a11472962c568a48d6f3955d0c2ddea80e0f9d [file] [log] [blame]
/* 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 __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 (1);
bar();
g (1);
#ifdef __OPTIMIZE__
if (ptr1 == ptr2)
abort ();
#endif
exit (0);
}
void bar(void) { }
#else /* NO_LABEL_VALUES */
int main() { exit(0); }
#endif