Message ID | 837fafa7-40db-c7f1-f501-ed058edbc289@redhat.com |
---|---|
State | New |
Headers | show |
On Mon, Jul 31, 2017 at 7:41 AM, Jeff Law <law@redhat.com> wrote: > This patch introduces some routines for logging of stack clash > protection actions. > > I don't think this patch changed at all relative to V2. Ok. Richard. > > Jeff > > > * function.c (dump_stack_clash_frame_info): New function. > * function.h (dump_stack_clash_frame_info): Prototype. > (enum stack_clash_probes): New enum. > > diff --git a/gcc/function.c b/gcc/function.c > index f625489..ca48b3f 100644 > --- a/gcc/function.c > +++ b/gcc/function.c > @@ -5695,6 +5695,58 @@ get_arg_pointer_save_area (void) > return ret; > } > > + > +/* If debugging dumps are requested, dump information about how the > + target handled -fstack-check=clash for the prologue. > + > + PROBES describes what if any probes were emitted. > + > + RESIDUALS indicates if the prologue had any residual allocation > + (i.e. total allocation was not a multiple of PROBE_INTERVAL). */ > + > +void > +dump_stack_clash_frame_info (enum stack_clash_probes probes, bool residuals) > +{ > + if (!dump_file) > + return; > + > + switch (probes) > + { > + case NO_PROBE_NO_FRAME: > + fprintf (dump_file, > + "Stack clash no probe no stack adjustment in prologue.\n"); > + break; > + case NO_PROBE_SMALL_FRAME: > + fprintf (dump_file, > + "Stack clash no probe small stack adjustment in prologue.\n"); > + break; > + case PROBE_INLINE: > + fprintf (dump_file, "Stack clash inline probes in prologue.\n"); > + break; > + case PROBE_LOOP: > + fprintf (dump_file, "Stack clash probe loop in prologue.\n"); > + break; > + } > + > + if (residuals) > + fprintf (dump_file, "Stack clash residual allocation in prologue.\n"); > + else > + fprintf (dump_file, "Stack clash no residual allocation in prologue.\n"); > + > + if (frame_pointer_needed) > + fprintf (dump_file, "Stack clash frame pointer needed.\n"); > + else > + fprintf (dump_file, "Stack clash no frame pointer needed.\n"); > + > + if (TREE_THIS_VOLATILE (cfun->decl)) > + fprintf (dump_file, > + "Stack clash noreturn prologue, assuming no implicit" > + " probes in caller.\n"); > + else > + fprintf (dump_file, > + "Stack clash not noreturn prologue.\n"); > +} > + > /* Add a list of INSNS to the hash HASHP, possibly allocating HASHP > for the first time. */ > > diff --git a/gcc/function.h b/gcc/function.h > index 0f34bcd..87dac80 100644 > --- a/gcc/function.h > +++ b/gcc/function.h > @@ -553,6 +553,14 @@ do { \ > ((TARGET_PTRMEMFUNC_VBIT_LOCATION == ptrmemfunc_vbit_in_pfn) \ > ? MAX (FUNCTION_BOUNDARY, 2 * BITS_PER_UNIT) : FUNCTION_BOUNDARY) > > +enum stack_clash_probes { > + NO_PROBE_NO_FRAME, > + NO_PROBE_SMALL_FRAME, > + PROBE_INLINE, > + PROBE_LOOP > +}; > + > +extern void dump_stack_clash_frame_info (enum stack_clash_probes, bool); > > > extern void push_function_context (void); >
diff --git a/gcc/function.c b/gcc/function.c index f625489..ca48b3f 100644 --- a/gcc/function.c +++ b/gcc/function.c @@ -5695,6 +5695,58 @@ get_arg_pointer_save_area (void) return ret; } + +/* If debugging dumps are requested, dump information about how the + target handled -fstack-check=clash for the prologue. + + PROBES describes what if any probes were emitted. + + RESIDUALS indicates if the prologue had any residual allocation + (i.e. total allocation was not a multiple of PROBE_INTERVAL). */ + +void +dump_stack_clash_frame_info (enum stack_clash_probes probes, bool residuals) +{ + if (!dump_file) + return; + + switch (probes) + { + case NO_PROBE_NO_FRAME: + fprintf (dump_file, + "Stack clash no probe no stack adjustment in prologue.\n"); + break; + case NO_PROBE_SMALL_FRAME: + fprintf (dump_file, + "Stack clash no probe small stack adjustment in prologue.\n"); + break; + case PROBE_INLINE: + fprintf (dump_file, "Stack clash inline probes in prologue.\n"); + break; + case PROBE_LOOP: + fprintf (dump_file, "Stack clash probe loop in prologue.\n"); + break; + } + + if (residuals) + fprintf (dump_file, "Stack clash residual allocation in prologue.\n"); + else + fprintf (dump_file, "Stack clash no residual allocation in prologue.\n"); + + if (frame_pointer_needed) + fprintf (dump_file, "Stack clash frame pointer needed.\n"); + else + fprintf (dump_file, "Stack clash no frame pointer needed.\n"); + + if (TREE_THIS_VOLATILE (cfun->decl)) + fprintf (dump_file, + "Stack clash noreturn prologue, assuming no implicit" + " probes in caller.\n"); + else + fprintf (dump_file, + "Stack clash not noreturn prologue.\n"); +} + /* Add a list of INSNS to the hash HASHP, possibly allocating HASHP for the first time. */ diff --git a/gcc/function.h b/gcc/function.h index 0f34bcd..87dac80 100644 --- a/gcc/function.h +++ b/gcc/function.h @@ -553,6 +553,14 @@ do { \ ((TARGET_PTRMEMFUNC_VBIT_LOCATION == ptrmemfunc_vbit_in_pfn) \ ? MAX (FUNCTION_BOUNDARY, 2 * BITS_PER_UNIT) : FUNCTION_BOUNDARY) +enum stack_clash_probes { + NO_PROBE_NO_FRAME, + NO_PROBE_SMALL_FRAME, + PROBE_INLINE, + PROBE_LOOP +}; + +extern void dump_stack_clash_frame_info (enum stack_clash_probes, bool); extern void push_function_context (void);