aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/plugin/diagnostic-test-inlining-3.c
blob: 56c9546fb8497ca6069755a4674c684d0998de95 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
/* { dg-do compile } */
/* { dg-options "-Wno-attributes -fdiagnostics-show-caret -O1" } */

extern void __emit_warning (const char *message);

__attribute__((always_inline))
static void foo (void)
{
  __emit_warning ("message");
}

__attribute__((always_inline))
static void bar (void)
{
  foo ();
}

int main()
{
  bar ();
  return 0;
}

/* Reproducer for PR tree-optimization/83336: when optimization is
   enabled, but debuginfo isn't, the diagnostics subsystem doesn't
   report the full inlining chain at a middle-end warning.

   This is a copy of diagnostic-test-inlining-1.c, but with -O1.

   Ideally the diagnostics subsystem would report:
     In function 'foo', inlined from 'bar' at LOC A, inlined from 'main' at LOC B:
   but with -O1 it only reports:
     In function 'foo', inlined from 'main' at LOC A:

   This test case captures this behavior.  */

/* { dg-regexp "In function 'foo'," "" } */
/* { dg-regexp "    inlined from 'bar' at .+/diagnostic-test-inlining-3.c:15:3," "" } */
/* { dg-regexp "    inlined from 'main' at .+/diagnostic-test-inlining-3.c:20:3:" "" } */
/* { dg-warning "3: message" "" { target *-*-* } 9 } */
/* { dg-begin-multiline-output "" }
   __emit_warning ("message");
   ^~~~~~~~~~~~~~~~~~~~~~~~~~
   { dg-end-multiline-output "" } */