diff options
Diffstat (limited to 'gcc/config/mep/mep.c')
-rw-r--r-- | gcc/config/mep/mep.c | 124 |
1 files changed, 67 insertions, 57 deletions
diff --git a/gcc/config/mep/mep.c b/gcc/config/mep/mep.c index 1d75777eb18..02c825ad763 100644 --- a/gcc/config/mep/mep.c +++ b/gcc/config/mep/mep.c @@ -268,8 +268,6 @@ static const int mep_cmov_insns[] = { mep_cor3 }; -static int option_mtiny_specified = 0; - static void mep_set_leaf_registers (int enable) @@ -316,6 +314,58 @@ static const struct default_options mep_option_optimization_table[] = static void mep_option_override (void) { + unsigned int i; + int j; + cl_deferred_option *opt; + VEC(cl_deferred_option,heap) *vec + = (VEC(cl_deferred_option,heap) *) mep_deferred_options; + + FOR_EACH_VEC_ELT (cl_deferred_option, vec, i, opt) + { + switch (opt->opt_index) + { + case OPT_mivc2: + for (j = 0; j < 32; j++) + fixed_regs[j + 48] = 0; + for (j = 0; j < 32; j++) + call_used_regs[j + 48] = 1; + for (j = 6; j < 8; j++) + call_used_regs[j + 48] = 0; + +#define RN(n,s) reg_names[FIRST_CCR_REGNO + n] = s + RN (0, "$csar0"); + RN (1, "$cc"); + RN (4, "$cofr0"); + RN (5, "$cofr1"); + RN (6, "$cofa0"); + RN (7, "$cofa1"); + RN (15, "$csar1"); + + RN (16, "$acc0_0"); + RN (17, "$acc0_1"); + RN (18, "$acc0_2"); + RN (19, "$acc0_3"); + RN (20, "$acc0_4"); + RN (21, "$acc0_5"); + RN (22, "$acc0_6"); + RN (23, "$acc0_7"); + + RN (24, "$acc1_0"); + RN (25, "$acc1_1"); + RN (26, "$acc1_2"); + RN (27, "$acc1_3"); + RN (28, "$acc1_4"); + RN (29, "$acc1_5"); + RN (30, "$acc1_6"); + RN (31, "$acc1_7"); +#undef RN + break; + + default: + gcc_unreachable (); + } + } + if (flag_pic == 1) warning (OPT_fpic, "-fpic is not supported"); if (flag_pic == 2) @@ -326,9 +376,9 @@ mep_option_override (void) error ("only one of -ms and -ml may be given"); if (TARGET_M && TARGET_L) error ("only one of -mm and -ml may be given"); - if (TARGET_S && option_mtiny_specified) + if (TARGET_S && global_options_set.x_mep_tiny_cutoff) error ("only one of -ms and -mtiny= may be given"); - if (TARGET_M && option_mtiny_specified) + if (TARGET_M && global_options_set.x_mep_tiny_cutoff) error ("only one of -mm and -mtiny= may be given"); if (TARGET_OPT_CLIP && ! TARGET_OPT_MINMAX) warning (0, "-mclip currently has no effect without -mminmax"); @@ -345,7 +395,7 @@ mep_option_override (void) mep_tiny_cutoff = 65536; if (TARGET_M) mep_tiny_cutoff = 0; - if (TARGET_L && ! option_mtiny_specified) + if (TARGET_L && ! global_options_set.x_mep_tiny_cutoff) mep_tiny_cutoff = 0; if (TARGET_64BIT_CR_REGS) @@ -7260,76 +7310,36 @@ mep_address_cost (rtx addr ATTRIBUTE_UNUSED, bool ATTRIBUTE_UNUSED speed_p) } static bool -mep_handle_option (struct gcc_options *opts, struct gcc_options *opts_set, +mep_handle_option (struct gcc_options *opts, + struct gcc_options *opts_set ATTRIBUTE_UNUSED, const struct cl_decoded_option *decoded, location_t loc ATTRIBUTE_UNUSED) { - int i; size_t code = decoded->opt_index; - gcc_assert (opts == &global_options); - gcc_assert (opts_set == &global_options_set); - switch (code) { case OPT_mall_opts: - target_flags |= MEP_ALL_OPTS; + opts->x_target_flags |= MEP_ALL_OPTS; break; case OPT_mno_opts: - target_flags &= ~ MEP_ALL_OPTS; + opts->x_target_flags &= ~ MEP_ALL_OPTS; break; case OPT_mcop64: - target_flags |= MASK_COP; - target_flags |= MASK_64BIT_CR_REGS; + opts->x_target_flags |= MASK_COP; + opts->x_target_flags |= MASK_64BIT_CR_REGS; break; - case OPT_mtiny_: - option_mtiny_specified = 1; - case OPT_mivc2: - target_flags |= MASK_COP; - target_flags |= MASK_64BIT_CR_REGS; - target_flags |= MASK_VLIW; - target_flags |= MASK_OPT_VL64; - target_flags |= MASK_IVC2; - - for (i=0; i<32; i++) - fixed_regs[i+48] = 0; - for (i=0; i<32; i++) - call_used_regs[i+48] = 1; - for (i=6; i<8; i++) - call_used_regs[i+48] = 0; - -#define RN(n,s) reg_names[FIRST_CCR_REGNO + n] = s - RN (0, "$csar0"); - RN (1, "$cc"); - RN (4, "$cofr0"); - RN (5, "$cofr1"); - RN (6, "$cofa0"); - RN (7, "$cofa1"); - RN (15, "$csar1"); - - RN (16, "$acc0_0"); - RN (17, "$acc0_1"); - RN (18, "$acc0_2"); - RN (19, "$acc0_3"); - RN (20, "$acc0_4"); - RN (21, "$acc0_5"); - RN (22, "$acc0_6"); - RN (23, "$acc0_7"); - - RN (24, "$acc1_0"); - RN (25, "$acc1_1"); - RN (26, "$acc1_2"); - RN (27, "$acc1_3"); - RN (28, "$acc1_4"); - RN (29, "$acc1_5"); - RN (30, "$acc1_6"); - RN (31, "$acc1_7"); -#undef RN + opts->x_target_flags |= MASK_COP; + opts->x_target_flags |= MASK_64BIT_CR_REGS; + opts->x_target_flags |= MASK_VLIW; + opts->x_target_flags |= MASK_OPT_VL64; + opts->x_target_flags |= MASK_IVC2; + /* Remaining handling of this option deferred. */ break; default: |