From b6968804f37fa999c090d7316ab59f40b14b5f49 Mon Sep 17 00:00:00 2001
From: Charles Baylis <charles.baylis@linaro.org>
Date: Wed, 8 Feb 2017 16:52:40 +0000
Subject: [PATCH 2/3] [ARM] Add table of costs for AAarch32 addressing modes.
This patch adds support for modelling the varying costs of
different addressing modes. The generic cost table treats
all addressing modes as having equal cost.
gcc/ChangeLog:
<date> Charles Baylis <charles.baylis@linaro.org>
* config/arm/aarch-common-protos.h (enum arm_addr_mode_op): New.
(struct addr_mode_cost_table): New.
(struct cpu_cost_table): Add pointer to an addr_mode_cost_table.
* config/arm/aarch-cost-tables.h: (generic_addr_mode_costs): New.
(generic_extra_costs) Initialise aarch32_addr_mode.
(cortexa53_extra_costs) Likewise.
(cortexa57_extra_costs) Likewise.
(exynosm1_extra_costs) Likewise.
(xgene1_extra_costs) Likewise.
(qdf24xx_extra_costs) Likewise.
* config/arm/arm.c (cortexa9_extra_costs) Initialise aarch32_addr_mode.
(cortexa9_extra_costs) Likewise.
(cortexa8_extra_costs) Likewise.
(cortexa5_extra_costs) Likewise.
(cortexa7_extra_costs) Likewise.
(cortexa12_extra_costs) Likewise.
(cortexv7m_extra_costs) Likewise.
(arm_mem_costs): Use table lookup to calculate cost of addressing
mode.
Change-Id: If71bd7c4f4bb876c5ed82dc28791130efb8bf89e
---
gcc/config/arm/aarch-common-protos.h | 20 +++++++++++++
gcc/config/arm/aarch-cost-tables.h | 38 +++++++++++++++++++----
gcc/config/arm/arm.c | 58 +++++++++++++++++++++++++++++++-----
3 files changed, 103 insertions(+), 13 deletions(-)
@@ -131,6 +131,25 @@ struct vector_cost_table
const int alu;
};
+/* Addressing mode operations. Used to index tables in struct
+ addr_mode_cost_table. */
+enum arm_addr_mode_op
+{
+ AMO_DEFAULT,
+ AMO_NO_WB, /* Offset with no writeback. */
+ AMO_WB, /* Offset with writeback. */
+ AMO_MAX /* For array size. */
+};
+
+/* Table of additional costs when using addressing modes for each
+ access type. */
+struct addr_mode_cost_table
+{
+ const int integer[AMO_MAX];
+ const int fp[AMO_MAX];
+ const int vector[AMO_MAX];
+};
+
struct cpu_cost_table
{
const struct alu_cost_table alu;
@@ -138,6 +157,7 @@ struct cpu_cost_table
const struct mem_cost_table ldst;
const struct fp_cost_table fp[2]; /* SFmode and DFmode. */
const struct vector_cost_table vect;
+ const struct addr_mode_cost_table *aarch32_addr_mode;
};
@@ -22,6 +22,29 @@
#ifndef GCC_AARCH_COST_TABLES_H
#define GCC_AARCH_COST_TABLES_H
+const struct addr_mode_cost_table generic_addr_mode_costs =
+{
+ /* int. */
+ {
+ 0, /* AMO_DEFAULT. */
+ 0, /* AMO_NO_WB. */
+ 0 /* AMO_WB. */
+ },
+ /* float. */
+ {
+ 0, /* AMO_DEFAULT. */
+ 0, /* AMO_NO_WB. */
+ 0 /* AMO_WB. */
+ },
+ /* vector. */
+ {
+ 0, /* AMO_DEFAULT. */
+ 0, /* AMO_NO_WB. */
+ 0 /* AMO_WB. */
+ }
+};
+
+
const struct cpu_cost_table generic_extra_costs =
{
/* ALU */
@@ -122,7 +145,8 @@ const struct cpu_cost_table generic_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table cortexa53_extra_costs =
@@ -225,7 +249,8 @@ const struct cpu_cost_table cortexa53_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table cortexa57_extra_costs =
@@ -328,7 +353,8 @@ const struct cpu_cost_table cortexa57_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table exynosm1_extra_costs =
@@ -431,7 +457,8 @@ const struct cpu_cost_table exynosm1_extra_costs =
/* Vector */
{
COSTS_N_INSNS (0) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table xgene1_extra_costs =
@@ -534,7 +561,8 @@ const struct cpu_cost_table xgene1_extra_costs =
/* Vector */
{
COSTS_N_INSNS (2) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
#endif /* GCC_AARCH_COST_TABLES_H */
@@ -1117,7 +1117,8 @@ const struct cpu_cost_table cortexa9_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table cortexa8_extra_costs =
@@ -1220,7 +1221,8 @@ const struct cpu_cost_table cortexa8_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table cortexa5_extra_costs =
@@ -1324,7 +1326,8 @@ const struct cpu_cost_table cortexa5_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
@@ -1429,7 +1432,8 @@ const struct cpu_cost_table cortexa7_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table cortexa12_extra_costs =
@@ -1532,7 +1536,8 @@ const struct cpu_cost_table cortexa12_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table cortexa15_extra_costs =
@@ -1635,7 +1640,8 @@ const struct cpu_cost_table cortexa15_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct cpu_cost_table v7m_extra_costs =
@@ -1738,7 +1744,8 @@ const struct cpu_cost_table v7m_extra_costs =
/* Vector */
{
COSTS_N_INSNS (1) /* alu. */
- }
+ },
+ &generic_addr_mode_costs /* aarch32_addr_mode. */
};
const struct tune_params arm_slowmul_tune =
@@ -9219,7 +9226,42 @@ arm_mem_costs (rtx x, const struct cpu_cost_table *extra_cost,
/* Calculate cost of the addressing mode. */
if (speed_p)
{
- /* TODO: Add table-driven costs for addressing modes. (See patch 2) */
+ arm_addr_mode_op op_type;
+ switch (GET_CODE (XEXP (x, 0)))
+ {
+ default:
+ case REG:
+ op_type = AMO_DEFAULT;
+ break;
+ case MINUS:
+ /* MINUS does not appear in RTL, but the architecture supports it,
+ so handle this case defensively. */
+ /* fall through */
+ case PLUS:
+ op_type = AMO_NO_WB;
+ break;
+ case PRE_INC:
+ case PRE_DEC:
+ case POST_INC:
+ case POST_DEC:
+ case PRE_MODIFY:
+ case POST_MODIFY:
+ op_type = AMO_WB;
+ break;
+ }
+
+ if (VECTOR_MODE_P (mode))
+ {
+ *cost += extra_cost->aarch32_addr_mode->vector[op_type];
+ }
+ else if (FLOAT_MODE_P (mode))
+ {
+ *cost += extra_cost->aarch32_addr_mode->fp[op_type];
+ }
+ else
+ {
+ *cost += extra_cost->aarch32_addr_mode->integer[op_type];
+ }
}
/* Calculate cost of memory access. */
--
2.7.4