This patch updates the register move tunings for
-mcpu/-mtune={neoverse-v1,neoverse-512tvb}.
gcc/ChangeLog:
2022-03-22 Tamar Christina <tamar.christina@arm.com>
Andre Vieira <andre.simoesdiasvieira@arm.com>
* config/aarch64/aarch64.cc (neoversev1_regmove_cost): New tuning
struct.
(neoversev1_tunings): Use neoversev1_regmove_cost and update store_int
cost.
(neoverse512tvb_tunings): Likewise.
2 /* FP2FP */
};
+static const struct cpu_regmove_cost neoversev1_regmove_cost =
+{
+ 1, /* GP2GP */
+ /* Spilling to int<->fp instead of memory is recommended so set
+ realistic costs compared to memmov_cost. */
+ 3, /* GP2FP */
+ 2, /* FP2GP */
+ 2 /* FP2FP */
+};
+
static const struct cpu_regmove_cost demeter_regmove_cost =
{
1, /* GP2GP */
{
&cortexa76_extra_costs,
&neoversev1_addrcost_table,
- &generic_regmove_cost,
+ &neoversev1_regmove_cost,
&neoversev1_vector_cost,
&generic_branch_cost,
&generic_approx_modes,
SVE_256, /* sve_width */
{ 4, /* load_int. */
- 1, /* store_int. */
+ 2, /* store_int. */
6, /* load_fp. */
2, /* store_fp. */
6, /* load_pred. */
{
&cortexa76_extra_costs,
&neoversev1_addrcost_table,
- &generic_regmove_cost,
+ &neoversev1_regmove_cost,
&neoverse512tvb_vector_cost,
&generic_branch_cost,
&generic_approx_modes,
SVE_128 | SVE_256, /* sve_width */
{ 4, /* load_int. */
- 1, /* store_int. */
+ 2, /* store_int. */
6, /* load_fp. */
2, /* store_fp. */
6, /* load_pred. */