annotate gcc/common/config/tilegx/tilegx-common.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Common hooks for TILE-Gx.
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 Copyright (C) 2011-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3 Contributed by Walter Lee (walt@tilera.com)
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is part of GCC.
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 GCC is free software; you can redistribute it and/or modify it
kono
parents:
diff changeset
8 under the terms of the GNU General Public License as published
kono
parents:
diff changeset
9 by the Free Software Foundation; either version 3, or (at your
kono
parents:
diff changeset
10 option) any later version.
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 GCC is distributed in the hope that it will be useful, but WITHOUT
kono
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
kono
parents:
diff changeset
14 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
kono
parents:
diff changeset
15 License for more details.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
18 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
19 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 #include "config.h"
kono
parents:
diff changeset
22 #include "system.h"
kono
parents:
diff changeset
23 #include "coretypes.h"
kono
parents:
diff changeset
24 #include "diagnostic-core.h"
kono
parents:
diff changeset
25 #include "tm.h"
kono
parents:
diff changeset
26 #include "common/common-target.h"
kono
parents:
diff changeset
27 #include "common/common-target-def.h"
kono
parents:
diff changeset
28 #include "opts.h"
kono
parents:
diff changeset
29 #include "flags.h"
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 static const struct default_options tilegx_option_optimization_table[] = {
kono
parents:
diff changeset
32 /* Scheduling and bundling are super important for our architecture, so
kono
parents:
diff changeset
33 enable them at -O1. */
kono
parents:
diff changeset
34 {OPT_LEVELS_1_PLUS, OPT_fschedule_insns, NULL, 1},
kono
parents:
diff changeset
35 {OPT_LEVELS_1_PLUS, OPT_fschedule_insns2, NULL, 1},
kono
parents:
diff changeset
36 {OPT_LEVELS_NONE, 0, NULL, 0}
kono
parents:
diff changeset
37 };
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 static void
kono
parents:
diff changeset
41 tilegx_option_init_struct (struct gcc_options *opts)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 opts->x_flag_asynchronous_unwind_tables = 1;
kono
parents:
diff changeset
44 }
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 #undef TARGET_DEFAULT_TARGET_FLAGS
kono
parents:
diff changeset
48 #define TARGET_DEFAULT_TARGET_FLAGS \
kono
parents:
diff changeset
49 (TARGET_DEFAULT \
kono
parents:
diff changeset
50 | TARGET_ENDIAN_DEFAULT)
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 #undef TARGET_OPTION_OPTIMIZATION_TABLE
kono
parents:
diff changeset
53 #define TARGET_OPTION_OPTIMIZATION_TABLE tilegx_option_optimization_table
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 #undef TARGET_OPTION_INIT_STRUCT
kono
parents:
diff changeset
56 #define TARGET_OPTION_INIT_STRUCT tilegx_option_init_struct
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 struct gcc_targetm_common targetm_common = TARGETM_COMMON_INITIALIZER;