genautomata.c cleanup

* genattr.c (main): Change 'rtx' to 'rtx_insn *' in prototypes of
	'insn_latency', 'maximal_insn_latency', 'min_insn_conflict_delay'.
	* genautomata.c (output_internal_insn_code_evaluation): Simplify.
	Move handling of non-insn arguments inline into the sole user:
	(output_trans_func): ...here.
	(output_min_insn_conflict_delay_func): Change 'rtx' to 'rtx_insn *'
	in emitted function prototype.
	(output_internal_insn_latency_func): Ditto.  Simplify.
	(output_internal_maximal_insn_latency_func): Ditto.  Delete
	always-unused argument.
	(output_insn_latency_func): Ditto.
	(output_maximal_insn_latency_func): Ditto.

From-SVN: r236132
This commit is contained in:
Alexander Monakov 2016-05-11 21:13:11 +03:00 committed by Alexander Monakov
parent 2c74f63ff5
commit d8aecc553d
3 changed files with 58 additions and 68 deletions

View File

@ -1,3 +1,18 @@
2016-05-11 Alexander Monakov <amonakov@ispras.ru>
* genattr.c (main): Change 'rtx' to 'rtx_insn *' in prototypes of
'insn_latency', 'maximal_insn_latency', 'min_insn_conflict_delay'.
* genautomata.c (output_internal_insn_code_evaluation): Simplify.
Move handling of non-insn arguments inline into the sole user:
(output_trans_func): ...here.
(output_min_insn_conflict_delay_func): Change 'rtx' to 'rtx_insn *'
in emitted function prototype.
(output_internal_insn_latency_func): Ditto. Simplify.
(output_internal_maximal_insn_latency_func): Ditto. Delete
always-unused argument.
(output_insn_latency_func): Ditto.
(output_maximal_insn_latency_func): Ditto.
2016-05-11 Richard Biener <rguenther@suse.de>
PR tree-optimization/71055

View File

@ -240,11 +240,11 @@ main (int argc, const char **argv)
printf ("/* Insn latency time on data consumed by the 2nd insn.\n");
printf (" Use the function if bypass_p returns nonzero for\n");
printf (" the 1st insn. */\n");
printf ("extern int insn_latency (rtx, rtx);\n\n");
printf ("extern int insn_latency (rtx_insn *, rtx_insn *);\n\n");
printf ("/* Maximal insn latency time possible of all bypasses for this insn.\n");
printf (" Use the function if bypass_p returns nonzero for\n");
printf (" the 1st insn. */\n");
printf ("extern int maximal_insn_latency (rtx);\n\n");
printf ("extern int maximal_insn_latency (rtx_insn *);\n\n");
printf ("\n#if AUTOMATON_ALTS\n");
printf ("/* The following function returns number of alternative\n");
printf (" reservations of given insn. It may be used for better\n");
@ -290,8 +290,8 @@ main (int argc, const char **argv)
printf (" state_transition should return negative value for\n");
printf (" the insn and the state). Data dependencies between\n");
printf (" the insns are ignored by the function. */\n");
printf
("extern int min_insn_conflict_delay (state_t, rtx, rtx);\n");
printf ("extern int "
"min_insn_conflict_delay (state_t, rtx_insn *, rtx_insn *);\n");
printf ("/* The following function outputs reservations for given\n");
printf (" insn as they are described in the corresponding\n");
printf (" define_insn_reservation. */\n");

View File

@ -8113,14 +8113,10 @@ output_internal_trans_func (void)
/* Output code
if (insn != 0)
{
insn_code = dfa_insn_code (insn);
if (insn_code > DFA__ADVANCE_CYCLE)
return code;
}
else
insn_code = DFA__ADVANCE_CYCLE;
gcc_checking_assert (insn != 0);
insn_code = dfa_insn_code (insn);
if (insn_code >= DFA__ADVANCE_CYCLE)
return code;
where insn denotes INSN_NAME, insn_code denotes INSN_CODE_NAME, and
code denotes CODE. */
@ -8129,21 +8125,12 @@ output_internal_insn_code_evaluation (const char *insn_name,
const char *insn_code_name,
int code)
{
fprintf (output_file, "\n if (%s == 0)\n", insn_name);
fprintf (output_file, " %s = %s;\n\n",
insn_code_name, ADVANCE_CYCLE_VALUE_NAME);
if (collapse_flag)
{
fprintf (output_file, "\n else if (%s == const0_rtx)\n", insn_name);
fprintf (output_file, " %s = %s;\n\n",
insn_code_name, COLLAPSE_NDFA_VALUE_NAME);
}
fprintf (output_file, "\n else\n {\n");
fprintf (output_file,
" %s = %s (as_a <rtx_insn *> (%s));\n",
insn_code_name, DFA_INSN_CODE_FUNC_NAME, insn_name);
fprintf (output_file, " if (%s > %s)\n return %d;\n }\n",
insn_code_name, ADVANCE_CYCLE_VALUE_NAME, code);
fprintf (output_file, " gcc_checking_assert (%s != 0);\n"
" %s = %s (%s);\n"
" if (%s >= %s)\n return %d;\n",
insn_name,
insn_code_name, DFA_INSN_CODE_FUNC_NAME, insn_name,
insn_code_name, ADVANCE_CYCLE_VALUE_NAME, code);
}
@ -8204,8 +8191,22 @@ output_trans_func (void)
TRANSITION_FUNC_NAME, STATE_TYPE_NAME, STATE_NAME,
INSN_PARAMETER_NAME);
fprintf (output_file, "{\n int %s;\n", INTERNAL_INSN_CODE_NAME);
output_internal_insn_code_evaluation (INSN_PARAMETER_NAME,
INTERNAL_INSN_CODE_NAME, -1);
fprintf (output_file, "\n if (%s == 0)\n", INSN_PARAMETER_NAME);
fprintf (output_file, " %s = %s;\n",
INTERNAL_INSN_CODE_NAME, ADVANCE_CYCLE_VALUE_NAME);
if (collapse_flag)
{
fprintf (output_file, " else if (%s == const0_rtx)\n",
INSN_PARAMETER_NAME);
fprintf (output_file, " %s = %s;\n",
INTERNAL_INSN_CODE_NAME, COLLAPSE_NDFA_VALUE_NAME);
}
fprintf (output_file, " else\n {\n");
fprintf (output_file, " %s = %s (as_a <rtx_insn *> (%s));\n",
INTERNAL_INSN_CODE_NAME, DFA_INSN_CODE_FUNC_NAME,
INSN_PARAMETER_NAME);
fprintf (output_file, " if (%s > %s)\n return -1;\n }\n",
INTERNAL_INSN_CODE_NAME, ADVANCE_CYCLE_VALUE_NAME);
fprintf (output_file, " return %s (%s, (struct %s *) %s);\n}\n\n",
INTERNAL_TRANSITION_FUNC_NAME, INTERNAL_INSN_CODE_NAME, CHIP_NAME, STATE_NAME);
}
@ -8297,7 +8298,7 @@ static void
output_min_insn_conflict_delay_func (void)
{
fprintf (output_file,
"int\n%s (%s %s, rtx %s, rtx %s)\n",
"int\n%s (%s %s, rtx_insn *%s, rtx_insn *%s)\n",
MIN_INSN_CONFLICT_DELAY_FUNC_NAME, STATE_TYPE_NAME,
STATE_NAME, INSN_PARAMETER_NAME, INSN2_PARAMETER_NAME);
fprintf (output_file, "{\n struct %s %s;\n int %s, %s, transition;\n",
@ -8366,10 +8367,12 @@ output_internal_insn_latency_func (void)
decl_t decl;
struct bypass_decl *bypass;
fprintf (output_file, "static int\n%s (int %s ATTRIBUTE_UNUSED,\n\tint %s ATTRIBUTE_UNUSED,\n\trtx %s ATTRIBUTE_UNUSED,\n\trtx %s ATTRIBUTE_UNUSED)\n",
INTERNAL_INSN_LATENCY_FUNC_NAME, INTERNAL_INSN_CODE_NAME,
INTERNAL_INSN2_CODE_NAME, "insn_or_const0",
"insn2_or_const0");
fprintf (output_file, "static int\n"
"%s (int %s ATTRIBUTE_UNUSED, int %s ATTRIBUTE_UNUSED,\n"
"\trtx_insn *%s ATTRIBUTE_UNUSED, rtx_insn *%s ATTRIBUTE_UNUSED)\n",
INTERNAL_INSN_LATENCY_FUNC_NAME,
INTERNAL_INSN_CODE_NAME, INTERNAL_INSN2_CODE_NAME,
INSN_PARAMETER_NAME, INSN2_PARAMETER_NAME);
fprintf (output_file, "{\n");
if (DECL_INSN_RESERV (advance_cycle_insn_decl)->insn_num == 0)
@ -8378,32 +8381,6 @@ output_internal_insn_latency_func (void)
return;
}
fprintf (output_file, " if (%s >= %s || %s >= %s)\n return 0;\n",
INTERNAL_INSN_CODE_NAME, ADVANCE_CYCLE_VALUE_NAME,
INTERNAL_INSN2_CODE_NAME, ADVANCE_CYCLE_VALUE_NAME);
/* We've now rejected the case that
INTERNAL_INSN_CODE_NAME >= ADVANCE_CYCLE_VALUE_NAME
i.e. that
insn_code >= DFA__ADVANCE_CYCLE,
and similarly for insn2_code. */
fprintf (output_file,
" /* Within output_internal_insn_code_evaluation, the generated\n"
" code sets \"code\" to NDFA__COLLAPSE for const0_rtx, and\n"
" NDFA__COLLAPSE > DFA__ADVANCE_CYCLE. Hence we can't be\n"
" dealing with const0_rtx instances at this point. */\n");
if (collapse_flag)
fprintf (output_file,
" gcc_assert (NDFA__COLLAPSE > DFA__ADVANCE_CYCLE);\n");
fprintf (output_file,
(" gcc_assert (insn_or_const0 != const0_rtx);\n"
" rtx_insn *%s ATTRIBUTE_UNUSED = safe_as_a <rtx_insn *> (insn_or_const0);\n"),
INSN_PARAMETER_NAME);
fprintf (output_file,
(" gcc_assert (insn2_or_const0 != const0_rtx);\n"
" rtx_insn *%s ATTRIBUTE_UNUSED = safe_as_a <rtx_insn *> (insn2_or_const0);\n"),
INSN2_PARAMETER_NAME);
fprintf (output_file, " switch (%s)\n {\n", INTERNAL_INSN_CODE_NAME);
for (i = 0; i < description->decls_num; i++)
if (description->decls[i]->mode == dm_insn_reserv
@ -8466,9 +8443,8 @@ output_internal_maximal_insn_latency_func (void)
int i;
int max;
fprintf (output_file, "static int\n%s (int %s ATTRIBUTE_UNUSED,\n\trtx %s ATTRIBUTE_UNUSED)\n",
"internal_maximal_insn_latency", INTERNAL_INSN_CODE_NAME,
INSN_PARAMETER_NAME);
fprintf (output_file, "static int\n%s (int %s ATTRIBUTE_UNUSED)\n",
"internal_maximal_insn_latency", INTERNAL_INSN_CODE_NAME);
fprintf (output_file, "{\n");
if (DECL_INSN_RESERV (advance_cycle_insn_decl)->insn_num == 0)
@ -8505,7 +8481,7 @@ output_internal_maximal_insn_latency_func (void)
static void
output_insn_latency_func (void)
{
fprintf (output_file, "int\n%s (rtx %s, rtx %s)\n",
fprintf (output_file, "int\n%s (rtx_insn *%s, rtx_insn *%s)\n",
INSN_LATENCY_FUNC_NAME, INSN_PARAMETER_NAME, INSN2_PARAMETER_NAME);
fprintf (output_file, "{\n int %s, %s;\n",
INTERNAL_INSN_CODE_NAME, INTERNAL_INSN2_CODE_NAME);
@ -8523,15 +8499,14 @@ output_insn_latency_func (void)
static void
output_maximal_insn_latency_func (void)
{
fprintf (output_file, "int\n%s (rtx %s)\n",
fprintf (output_file, "int\n%s (rtx_insn *%s)\n",
"maximal_insn_latency", INSN_PARAMETER_NAME);
fprintf (output_file, "{\n int %s;\n",
INTERNAL_INSN_CODE_NAME);
output_internal_insn_code_evaluation (INSN_PARAMETER_NAME,
INTERNAL_INSN_CODE_NAME, 0);
fprintf (output_file, " return %s (%s, %s);\n}\n\n",
"internal_maximal_insn_latency",
INTERNAL_INSN_CODE_NAME, INSN_PARAMETER_NAME);
fprintf (output_file, " return %s (%s);\n}\n\n",
"internal_maximal_insn_latency", INTERNAL_INSN_CODE_NAME);
}
/* The function outputs PHR interface function `print_reservation'. */