commit 31c8614cbe32a81960c9d8634f2c06534492b515
Author: Julian Brown <julian@henry7.codesourcery.com>
Date: Fri May 27 10:39:01 2011 -0700
Make branch cost a tunable parameter.
@@ -225,6 +225,7 @@ struct tune_params
int l1_cache_size;
int l1_cache_line_size;
bool prefer_constant_pool;
+ int (*branch_cost) (bool, bool);
};
extern const struct tune_params *current_tune;
@@ -255,6 +255,7 @@ static bool arm_builtin_support_vector_misalignment (enum machine_mode mode,
static void arm_conditional_register_usage (void);
static reg_class_t arm_preferred_rename_class (reg_class_t rclass);
static unsigned int arm_autovectorize_vector_sizes (void);
+static int arm_default_branch_cost (bool, bool);
/* Table of machine attributes. */
@@ -856,7 +857,8 @@ const struct tune_params arm_slowmul_tune =
NULL,
3, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- true /* Prefer constant pool. */
+ true, /* Prefer constant pool. */
+ arm_default_branch_cost
};
const struct tune_params arm_fastmul_tune =
@@ -865,7 +867,8 @@ const struct tune_params arm_fastmul_tune =
NULL,
1, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- true /* Prefer constant pool. */
+ true, /* Prefer constant pool. */
+ arm_default_branch_cost
};
const struct tune_params arm_xscale_tune =
@@ -874,7 +877,8 @@ const struct tune_params arm_xscale_tune =
xscale_sched_adjust_cost,
2, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- true /* Prefer constant pool. */
+ true, /* Prefer constant pool. */
+ arm_default_branch_cost
};
const struct tune_params arm_9e_tune =
@@ -883,7 +887,8 @@ const struct tune_params arm_9e_tune =
NULL,
1, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- true /* Prefer constant pool. */
+ true, /* Prefer constant pool. */
+ arm_default_branch_cost
};
const struct tune_params arm_v6t2_tune =
@@ -892,7 +897,8 @@ const struct tune_params arm_v6t2_tune =
NULL,
1, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- false /* Prefer constant pool. */
+ false, /* Prefer constant pool. */
+ arm_default_branch_cost
};
/* Generic Cortex tuning. Use more specific tunings if appropriate. */
@@ -902,7 +908,8 @@ const struct tune_params arm_cortex_tune =
NULL,
1, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- false /* Prefer constant pool. */
+ false, /* Prefer constant pool. */
+ arm_default_branch_cost
};
const struct tune_params arm_cortex_a9_tune =
@@ -911,7 +918,8 @@ const struct tune_params arm_cortex_a9_tune =
cortex_a9_sched_adjust_cost,
1, /* Constant limit. */
ARM_PREFETCH_BENEFICIAL(4,32,32),
- false /* Prefer constant pool. */
+ false, /* Prefer constant pool. */
+ arm_default_branch_cost
};
const struct tune_params arm_fa726te_tune =
@@ -920,7 +928,8 @@ const struct tune_params arm_fa726te_tune =
fa726te_sched_adjust_cost,
1, /* Constant limit. */
ARM_PREFETCH_NOT_BENEFICIAL,
- true /* Prefer constant pool. */
+ true, /* Prefer constant pool. */
+ arm_default_branch_cost
};
@@ -8080,6 +8089,15 @@ arm_adjust_cost (rtx insn, rtx link, rtx dep, int cost)
return cost;
}
+static int
+arm_default_branch_cost (bool speed_p, bool predictable_p ATTRIBUTE_UNUSED)
+{
+ if (TARGET_32BIT)
+ return (TARGET_THUMB2 && !speed_p) ? 1 : 4;
+ else
+ return (optimize > 0) ? 2 : 0;
+}
+
static int fp_consts_inited = 0;
/* Only zero is valid for VFP. Other values are also valid for FPA. */
@@ -1947,8 +1947,8 @@ typedef struct
/* Try to generate sequences that don't involve branches, we can then use
conditional instructions */
#define BRANCH_COST(speed_p, predictable_p) \
- (TARGET_32BIT ? (TARGET_THUMB2 && !speed_p ? 1 : 4) \
- : (optimize > 0 ? 2 : 0))
+ (current_tune->branch_cost (speed_p, predictable_p))
+
/* Position Independent Code. */
/* We decide which register to use based on the compilation options and
@@ -36,6 +36,7 @@ along with GCC; see the file COPYING3. If not see
#include "ggc.h"
#include "basic-block.h"
#include "output.h"
+#include "tm_p.h"
static bool prefer_and_bit_test (enum machine_mode, int);
static void do_jump_by_parts_greater (tree, tree, int, rtx, rtx, int);