* Claudiu Zissulescu <claz...@gmail.com> [2018-05-21 13:20:29 +0300]:

> From: claziss <claz...@synopsys.com>
> 
> When we pass an mcpu to the compiler we have two types of (hardware
> configuration) flags that are set:
> 
> 1. Architecture specific, for example code-density is always enabled
> for ARCHS architectures. These options are overwriting whatever the
> corresponding user options with the preset ones.
> 
> 2. CPU specific, for example archs is using LL64 option by
> default. These options can be freely enabled or disabled.
> 
> Because of the above complexity, we need to throw some errors for the
> user to know when he/she does something which goes against the above
> rules. Thus, I came up with the following set of rules:
> 
> 1. Overwriting default architecture specific hardware option: it is
> ignored, a warning is thrown;
> 
> 2. Overwriting default CPU specific hardware option: it is taken into
> account, a warning is thrown.
> 
> Ok to apply?
> Claudiu

This seems fine.

Thanks,
Andrew

> 
> gcc/
> 2017-09-26  Claudiu Zissulescu  <claz...@synopsys.com>
> 
>       * config/arc/arc-arch.h: Update ARC_OPTX macro.
>       * config/arc/arc-options.def (ARC_OPTX): Introduce a new doc
>       field.
>       * config/arc/arc.c (arc_init): Update pic warning.
>       (irq_range): Update irq range parsing warnings.
>       (arc_override_options): Update various warning messages.
>       (arc_handle_aux_attribute): Likewise.
> 
> gcc/testsuite
> 2017-09-26  Claudiu Zissulescu  <claz...@synopsys.com>
> 
>       * gcc.target/arc/builtin_simdarc.c: Update test.
>       * gcc.target/arc/mulsi3_highpart-2.c: Likewise.
>       * gcc.target/arc/tumaddsidi4.c: Likewise.
> ---
>  gcc/config/arc/arc-arch.h                        |  2 +-
>  gcc/config/arc/arc-options.def                   | 44 ++++++------
>  gcc/config/arc/arc.c                             | 90 
> ++++++++++++++----------
>  gcc/testsuite/gcc.target/arc/builtin_simdarc.c   |  2 +-
>  gcc/testsuite/gcc.target/arc/mulsi3_highpart-2.c |  2 +-
>  gcc/testsuite/gcc.target/arc/tumaddsidi4.c       |  2 +-
>  6 files changed, 80 insertions(+), 62 deletions(-)
> 
> diff --git a/gcc/config/arc/arc-arch.h b/gcc/config/arc/arc-arch.h
> index f90be66e200..a3b7dc87be4 100644
> --- a/gcc/config/arc/arc-arch.h
> +++ b/gcc/config/arc/arc-arch.h
> @@ -28,7 +28,7 @@ along with GCC; see the file COPYING3.  If not see
>  enum cpu_flags
>    {
>  #define ARC_OPT(NAME, CODE, MASK, DOC)           NAME = CODE,
> -#define ARC_OPTX(NAME, CODE, VAR, VAL, DOC) NAME = CODE,
> +#define ARC_OPTX(NAME, CODE, VAR, VAL, DOC0, DOC1) NAME = CODE,
>  #include "arc-options.def"
>  #undef ARC_OPT
>  #undef ARC_OPTX
> diff --git a/gcc/config/arc/arc-options.def b/gcc/config/arc/arc-options.def
> index 61ecd1de150..fefb3081c81 100644
> --- a/gcc/config/arc/arc-options.def
> +++ b/gcc/config/arc/arc-options.def
> @@ -74,32 +74,32 @@ ARC_OPT (FL_DPFP,     (1ULL << 13), 
> MASK_DPFP_COMPACT_SET, "double precission FP
>  ARC_OPT (FL_ARGONAUT, (1ULL << 14), MASK_ARGONAUT_SET,          "argonaut")
>  ARC_OPT (FL_SIMD,     (1ULL << 15), MASK_SIMD_SET,      "simd")
>  
> -ARC_OPTX (FL_MPYOPT_1, (1ULL << 17), arc_mpy_option, 1, "mpy option w")
> -ARC_OPTX (FL_MPYOPT_2, (1ULL << 18), arc_mpy_option, 2, "mpy option wlh1")
> -ARC_OPTX (FL_MPYOPT_3, (1ULL << 19), arc_mpy_option, 3, "mpy option wlh2")
> -ARC_OPTX (FL_MPYOPT_4, (1ULL << 20), arc_mpy_option, 4, "mpy option wlh3")
> -ARC_OPTX (FL_MPYOPT_5, (1ULL << 21), arc_mpy_option, 5, "mpy option wlh4")
> -ARC_OPTX (FL_MPYOPT_6, (1ULL << 22), arc_mpy_option, 6, "mpy option wlh5")
> -ARC_OPTX (FL_MPYOPT_7, (1ULL << 23), arc_mpy_option, 7, "mpy option 
> plus_dmpy")
> -ARC_OPTX (FL_MPYOPT_8, (1ULL << 24), arc_mpy_option, 8, "mpy option 
> plus_macd")
> -ARC_OPTX (FL_MPYOPT_9, (1ULL << 25), arc_mpy_option, 9, "mpy option 
> plus_qmacw")
> +ARC_OPTX (FL_MPYOPT_1, (1ULL << 17), arc_mpy_option, 1, "mpy-option", "w")
> +ARC_OPTX (FL_MPYOPT_2, (1ULL << 18), arc_mpy_option, 2, "mpy-option", "wlh1")
> +ARC_OPTX (FL_MPYOPT_3, (1ULL << 19), arc_mpy_option, 3, "mpy-option", "wlh2")
> +ARC_OPTX (FL_MPYOPT_4, (1ULL << 20), arc_mpy_option, 4, "mpy-option", "wlh3")
> +ARC_OPTX (FL_MPYOPT_5, (1ULL << 21), arc_mpy_option, 5, "mpy-option", "wlh4")
> +ARC_OPTX (FL_MPYOPT_6, (1ULL << 22), arc_mpy_option, 6, "mpy-option", "wlh5")
> +ARC_OPTX (FL_MPYOPT_7, (1ULL << 23), arc_mpy_option, 7, "mpy-option", 
> "plus_dmpy")
> +ARC_OPTX (FL_MPYOPT_8, (1ULL << 24), arc_mpy_option, 8, "mpy-option", 
> "plus_macd")
> +ARC_OPTX (FL_MPYOPT_9, (1ULL << 25), arc_mpy_option, 9, "mpy-option", 
> "plus_qmacw")
>  
>  ARC_OPT (FL_MPYOPT_7_9, (0x01c2ULL << 17), 0, "mpy option")
>  ARC_OPT (FL_MPYOPT_1_6, (0x003fULL << 17), 0, "mpy option")
>  
> -ARC_OPTX (FL_FPU_FPUS,           (1ULL << 26), arc_fpu_build, FPU_FPUS,      
> "mfpu=fpus")
> -ARC_OPTX (FL_FPU_FPUS_DIV,  (1ULL << 27), arc_fpu_build, FPU_FPUS_DIV,       
> "mfpu=fpus_div")
> -ARC_OPTX (FL_FPU_FPUS_FMA,  (1ULL << 28), arc_fpu_build, FPU_FPUS_FMA,       
> "mfpu=fpus_fma")
> -ARC_OPTX (FL_FPU_FPUS_ALL,  (1ULL << 29), arc_fpu_build, FPU_FPUS_ALL,       
> "mfpu=fpus_all")
> -ARC_OPTX (FL_FPU_FPUDA,          (1ULL << 30), arc_fpu_build, FPU_FPUDA,     
> "mfpu=fpuda")
> -ARC_OPTX (FL_FPU_FPUDA_DIV, (1ULL << 31), arc_fpu_build, FPU_FPUDA_DIV, 
> "mfpu=fpuda_div")
> -ARC_OPTX (FL_FPU_FPUDA_FMA, (1ULL << 32), arc_fpu_build, FPU_FPUDA_FMA, 
> "mfpu=fpuda_fma")
> -ARC_OPTX (FL_FPU_FPUDA_ALL, (1ULL << 33), arc_fpu_build, FPU_FPUDA_ALL, 
> "mfpu=fpuda_all")
> -ARC_OPTX (FL_FPU_FPUD,           (1ULL << 34), arc_fpu_build, FPU_FPUD,      
> "mfpu=fpud")
> -ARC_OPTX (FL_FPU_FPUD_DIV,  (1ULL << 35), arc_fpu_build, FPU_FPUD_DIV,       
> "mfpu=fpud_div")
> -ARC_OPTX (FL_FPU_FPUD_FMA,  (1ULL << 36), arc_fpu_build, FPU_FPUD_FMA,       
> "mfpu=fpud_fma")
> -ARC_OPTX (FL_FPU_FPUD_ALL,  (1ULL << 37), arc_fpu_build, FPU_FPUD_ALL,       
> "mfpu=fpud_all")
> -ARC_OPTX (FL_FPX_QUARK,          (1ULL << 38), arc_fpu_build, FPX_QK,        
> "quarkse fp")
> +ARC_OPTX (FL_FPU_FPUS,           (1ULL << 26), arc_fpu_build, FPU_FPUS,      
> "mfpu", "fpus")
> +ARC_OPTX (FL_FPU_FPUS_DIV,  (1ULL << 27), arc_fpu_build, FPU_FPUS_DIV,       
> "mfpu", "fpus_div")
> +ARC_OPTX (FL_FPU_FPUS_FMA,  (1ULL << 28), arc_fpu_build, FPU_FPUS_FMA,       
> "mfpu", "fpus_fma")
> +ARC_OPTX (FL_FPU_FPUS_ALL,  (1ULL << 29), arc_fpu_build, FPU_FPUS_ALL,       
> "mfpu", "fpus_all")
> +ARC_OPTX (FL_FPU_FPUDA,          (1ULL << 30), arc_fpu_build, FPU_FPUDA,     
> "mfpu", "fpuda")
> +ARC_OPTX (FL_FPU_FPUDA_DIV, (1ULL << 31), arc_fpu_build, FPU_FPUDA_DIV, 
> "mfpu", "fpuda_div")
> +ARC_OPTX (FL_FPU_FPUDA_FMA, (1ULL << 32), arc_fpu_build, FPU_FPUDA_FMA, 
> "mfpu", "fpuda_fma")
> +ARC_OPTX (FL_FPU_FPUDA_ALL, (1ULL << 33), arc_fpu_build, FPU_FPUDA_ALL, 
> "mfpu", "fpuda_all")
> +ARC_OPTX (FL_FPU_FPUD,           (1ULL << 34), arc_fpu_build, FPU_FPUD,      
> "mfpu", "fpud")
> +ARC_OPTX (FL_FPU_FPUD_DIV,  (1ULL << 35), arc_fpu_build, FPU_FPUD_DIV,       
> "mfpu", "fpud_div")
> +ARC_OPTX (FL_FPU_FPUD_FMA,  (1ULL << 36), arc_fpu_build, FPU_FPUD_FMA,       
> "mfpu", "fpud_fma")
> +ARC_OPTX (FL_FPU_FPUD_ALL,  (1ULL << 37), arc_fpu_build, FPU_FPUD_ALL,       
> "mfpu", "fpud_all")
> +ARC_OPTX (FL_FPX_QUARK,          (1ULL << 38), arc_fpu_build, FPX_QK,        
> "quarkse fp", "N.A.")
>  
>  ARC_OPT (FL_FPUS,  (0xFULL << 26), 0, "single precission floating point")
>  ARC_OPT (FL_FPUDA, (0xFFULL << 26), 0, "double precission fp assist")
> diff --git a/gcc/config/arc/arc.c b/gcc/config/arc/arc.c
> index 56715a8f61d..b1a09d82b72 100644
> --- a/gcc/config/arc/arc.c
> +++ b/gcc/config/arc/arc.c
> @@ -953,7 +953,7 @@ arc_init (void)
>    /* Warn for unimplemented PIC in pre-ARC700 cores, and disable flag_pic.  
> */
>    if (flag_pic && TARGET_ARC600_FAMILY)
>      {
> -      warning (DK_WARNING,
> +      warning (0,
>              "PIC is not supported for %s. Generating non-PIC code only..",
>              arc_cpu_string);
>        flag_pic = 0;
> @@ -1017,7 +1017,7 @@ irq_range (const char *cstr)
>    dash = strchr (str, '-');
>    if (!dash)
>      {
> -      warning (0, "value of -mirq-ctrl-saved must have form R0-REGx");
> +      warning (OPT_mirq_ctrl_saved_, "missing dash");
>        return;
>      }
>    *dash = '\0';
> @@ -1029,7 +1029,7 @@ irq_range (const char *cstr)
>    first = decode_reg_name (str);
>    if (first != 0)
>      {
> -      warning (0, "first register must be R0");
> +      warning (OPT_mirq_ctrl_saved_, "first register must be R0");
>        return;
>      }
>  
> @@ -1042,13 +1042,14 @@ irq_range (const char *cstr)
>  
>    if (last < 0)
>      {
> -      warning (0, "unknown register name: %s", dash + 1);
> +      warning (OPT_mirq_ctrl_saved_, "unknown register name: %s", dash + 1);
>        return;
>      }
>  
>    if (!(last & 0x01))
>      {
> -      warning (0, "last register name %s must be an odd register", dash + 1);
> +      warning (OPT_mirq_ctrl_saved_,
> +            "last register name %s must be an odd register", dash + 1);
>        return;
>      }
>  
> @@ -1056,7 +1057,8 @@ irq_range (const char *cstr)
>  
>    if (first > last)
>      {
> -      warning (0, "%s-%s is an empty range", str, dash + 1);
> +      warning (OPT_mirq_ctrl_saved_,
> +            "%s-%s is an empty range", str, dash + 1);
>        return;
>      }
>  
> @@ -1081,7 +1083,8 @@ irq_range (const char *cstr)
>         break;
>  
>       default:
> -       warning (0, "unknown register name: %s", str);
> +       warning (OPT_mirq_ctrl_saved_,
> +                "unknown register name: %s", str);
>         return;
>       }
>      }
> @@ -1166,14 +1169,16 @@ arc_override_options (void)
>           if (TARGET_V2)
>             irq_range (opt->arg);
>           else
> -           warning (0, "option -mirq-ctrl-saved valid only for ARC v2 
> processors");
> +           warning (OPT_mirq_ctrl_saved_,
> +                    "option -mirq-ctrl-saved valid only for ARC v2 
> processors");
>           break;
>  
>         case OPT_mrgf_banked_regs_:
>           if (TARGET_V2)
>             parse_mrgf_banked_regs_option (opt->arg);
>           else
> -           warning (0, "option -mrgf-banked-regs valid only for ARC v2 
> processors");
> +           warning (OPT_mrgf_banked_regs_,
> +                    "option -mrgf-banked-regs valid only for ARC v2 
> processors");
>           break;
>  
>         default:
> @@ -1205,6 +1210,42 @@ arc_override_options (void)
>       }
>      }
>  
> +  /* Check options against architecture options.  Throw an error if
> +     option is not allowed.  Extra, check options against default
> +     architecture/cpu flags and throw an warning if we find a
> +     mismatch.  */
> +#define ARC_OPTX(NAME, CODE, VAR, VAL, DOC0, DOC1)           \
> +  do {                                                               \
> +    if ((!(arc_selected_cpu->arch_info->flags & CODE))               \
> +     && (VAR == VAL))                                        \
> +      error ("Option %s=%s is not available for %s CPU.",    \
> +          DOC0, DOC1, arc_selected_cpu->name);               \
> +    if ((arc_selected_cpu->arch_info->dflags & CODE)         \
> +     && (VAR != DEFAULT_##VAR)                               \
> +     && (VAR != VAL))                                        \
> +      warning (0, "Option %s is ignored, the default value %s"       \
> +            " is considered for %s CPU.", DOC0, DOC1,        \
> +            arc_selected_cpu->name);                         \
> + } while (0);
> +#define ARC_OPT(NAME, CODE, MASK, DOC)                               \
> +  do {                                                               \
> +    if ((!(arc_selected_cpu->arch_info->flags & CODE))               \
> +     && (target_flags & MASK))                               \
> +      error ("Option %s is not available for %s CPU",                \
> +          DOC, arc_selected_cpu->name);                      \
> +    if ((arc_selected_cpu->arch_info->dflags & CODE)         \
> +     && (target_flags_explicit & MASK)                       \
> +     && (!(target_flags & MASK)))                            \
> +      warning (0, "Unset option %s is ignored, it is always" \
> +            " enabled for %s CPU.", DOC,                     \
> +            arc_selected_cpu->name);                         \
> +  } while (0);
> +
> +#include "arc-options.def"
> +
> +#undef ARC_OPTX
> +#undef ARC_OPT
> +
>    /* Set cpu flags accordingly to architecture/selected cpu.  The cpu
>       specific flags are set in arc-common.c.  The architecture forces
>       the default hardware configurations in, regardless what command
> @@ -1218,7 +1259,7 @@ arc_override_options (void)
>      if (arc_selected_cpu->arch_info->dflags & CODE)  \
>        target_flags |= MASK;                          \
>    } while (0);
> -#define ARC_OPTX(NAME, CODE, VAR, VAL, DOC)          \
> +#define ARC_OPTX(NAME, CODE, VAR, VAL, DOC0, DOC1)   \
>    do {                                                       \
>      if ((arc_selected_cpu->flags & CODE)             \
>       && (VAR == DEFAULT_##VAR))                      \
> @@ -1229,30 +1270,6 @@ arc_override_options (void)
>  
>  #include "arc-options.def"
>  
> -#undef ARC_OPTX
> -#undef ARC_OPT
> -
> -  /* Check options against architecture options.  Throw an error if
> -     option is not allowed.  */
> -#define ARC_OPTX(NAME, CODE, VAR, VAL, DOC)                  \
> -  do {                                                               \
> -    if ((VAR == VAL)                                         \
> -     && (!(arc_selected_cpu->arch_info->flags & CODE)))      \
> -      {                                                              \
> -     error ("%s is not available for %s architecture",       \
> -            DOC, arc_selected_cpu->arch_info->name);         \
> -      }                                                              \
> -  } while (0);
> -#define ARC_OPT(NAME, CODE, MASK, DOC)                               \
> -  do {                                                               \
> -    if ((target_flags & MASK)                                        \
> -     && (!(arc_selected_cpu->arch_info->flags & CODE)))      \
> -      error ("%s is not available for %s architecture",              \
> -          DOC, arc_selected_cpu->arch_info->name);           \
> -  } while (0);
> -
> -#include "arc-options.def"
> -
>  #undef ARC_OPTX
>  #undef ARC_OPT
>  
> @@ -1278,7 +1295,8 @@ arc_override_options (void)
>      {
>        if (TARGET_COMPACT_CASESI)
>       {
> -       warning (0, "compact-casesi is not applicable to ARCv2");
> +       warning (OPT_mcompact_casesi,
> +                "compact-casesi is not applicable to ARCv2");
>         TARGET_COMPACT_CASESI = 0;
>       }
>      }
> @@ -10746,7 +10764,7 @@ arc_handle_aux_attribute (tree *node,
>         tree arg = TREE_VALUE (args);
>         if (TREE_CODE (arg) != INTEGER_CST)
>           {
> -           warning (0, "%qE attribute allows only an integer "
> +           warning (OPT_Wattributes, "%qE attribute allows only an integer "
>                      "constant argument", name);
>             *no_add_attrs = true;
>           }
> diff --git a/gcc/testsuite/gcc.target/arc/builtin_simdarc.c 
> b/gcc/testsuite/gcc.target/arc/builtin_simdarc.c
> index 0cfe2ad767d..5a7c8599199 100644
> --- a/gcc/testsuite/gcc.target/arc/builtin_simdarc.c
> +++ b/gcc/testsuite/gcc.target/arc/builtin_simdarc.c
> @@ -1,6 +1,6 @@
>  /* { dg-do compile } */
>  /* { dg-skip-if "" { ! { clmcpu } } } */
> -/* { dg-options "-mcpu=archs -O2 -Werror-implicit-function-declaration 
> -mmpy-option=9" } */
> +/* { dg-options "-mcpu=hs38 -O2 -Werror-implicit-function-declaration 
> -mmpy-option=9" } */
>  
>  #define STEST(name, rettype, op1type, op2type)       \
>    rettype test_ ## name                              \
> diff --git a/gcc/testsuite/gcc.target/arc/mulsi3_highpart-2.c 
> b/gcc/testsuite/gcc.target/arc/mulsi3_highpart-2.c
> index 6ec4bc5d875..4b54cbf6a52 100644
> --- a/gcc/testsuite/gcc.target/arc/mulsi3_highpart-2.c
> +++ b/gcc/testsuite/gcc.target/arc/mulsi3_highpart-2.c
> @@ -1,7 +1,7 @@
>  /* { dg-do run } */
>  /* { dg-skip-if "ARC700 always has mpy option on" { arc700 } } */
>  /* { dg-skip-if "ARC600 doesn't have mpy instruction" { arc6xx } } */
> -/* { dg-options "-O2 --save-temps -mmpy-option=0" } */
> +/* { dg-options "-O2 -mmpy-option=0 -w" } */
>  
>  #include <stdlib.h>
>  
> diff --git a/gcc/testsuite/gcc.target/arc/tumaddsidi4.c 
> b/gcc/testsuite/gcc.target/arc/tumaddsidi4.c
> index 40d2b3325f2..d5dc2944d9b 100755
> --- a/gcc/testsuite/gcc.target/arc/tumaddsidi4.c
> +++ b/gcc/testsuite/gcc.target/arc/tumaddsidi4.c
> @@ -1,5 +1,5 @@
>  /* { dg-do compile } */
> -/* { dg-options "-mcpu=archs -O1 -mmpy-option=plus_dmpy" } */
> +/* { dg-options "-mcpu=archs -O1 -mmpy-option=plus_dmpy -w" } */
>  
>  /* Check how we generate umaddsidi4 patterns.  */
>  long a;
> -- 
> 2.14.3
> 

Reply via email to