* function.c (dump_stack_clash_frame_info): New function. * function.h (dump_stack_clash_frame_info): Prototype. (enum stack_clash_probes): New enum. commit 3b09af4e78f3fdb40a913fbf99197a31315a47bc Author: root Date: Thu Jul 6 04:34:45 2017 -0400 Generic logging routines diff --git a/gcc/function.c b/gcc/function.c index f625489..d78a266 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 infomation 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 + (ie 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);