annotate gcc/common/config/tilegx/tilegx-common.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Common hooks for TILE-Gx.
kono
parents:
diff changeset
2 Copyright (C) 2011-2017 Free Software Foundation, Inc.
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 {OPT_LEVELS_1_PLUS, OPT_fomit_frame_pointer, NULL, 1},
kono
parents:
diff changeset
33 /* Scheduling and bundling are super important for our architecture, so
kono
parents:
diff changeset
34 enable them at -O1. */
kono
parents:
diff changeset
35 {OPT_LEVELS_1_PLUS, OPT_fschedule_insns, NULL, 1},
kono
parents:
diff changeset
36 {OPT_LEVELS_1_PLUS, OPT_fschedule_insns2, NULL, 1},
kono
parents:
diff changeset
37 {OPT_LEVELS_NONE, 0, NULL, 0}
kono
parents:
diff changeset
38 };
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 static void
kono
parents:
diff changeset
42 tilegx_option_init_struct (struct gcc_options *opts)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 opts->x_flag_asynchronous_unwind_tables = 1;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 #undef TARGET_DEFAULT_TARGET_FLAGS
kono
parents:
diff changeset
49 #define TARGET_DEFAULT_TARGET_FLAGS \
kono
parents:
diff changeset
50 (TARGET_DEFAULT \
kono
parents:
diff changeset
51 | TARGET_ENDIAN_DEFAULT)
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 #undef TARGET_OPTION_OPTIMIZATION_TABLE
kono
parents:
diff changeset
54 #define TARGET_OPTION_OPTIMIZATION_TABLE tilegx_option_optimization_table
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 #undef TARGET_OPTION_INIT_STRUCT
kono
parents:
diff changeset
57 #define TARGET_OPTION_INIT_STRUCT tilegx_option_init_struct
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 struct gcc_targetm_common targetm_common = TARGETM_COMMON_INITIALIZER;