annotate gcc/genattr-common.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Generate attribute information shared between driver and core
kono
parents:
diff changeset
2 compilers (insn-attr-common.h) from machine description. Split out
kono
parents:
diff changeset
3 of genattr.c.
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
4 Copyright (C) 1991-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 This file is part of GCC.
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
9 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
10 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
11 version.
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
16 for more details.
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
19 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
20 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 #include "bconfig.h"
kono
parents:
diff changeset
24 #include "system.h"
kono
parents:
diff changeset
25 #include "coretypes.h"
kono
parents:
diff changeset
26 #include "tm.h"
kono
parents:
diff changeset
27 #include "rtl.h"
kono
parents:
diff changeset
28 #include "errors.h"
kono
parents:
diff changeset
29 #include "read-md.h"
kono
parents:
diff changeset
30 #include "gensupport.h"
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 static void
kono
parents:
diff changeset
33 write_upcase (const char *str)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 for (; *str; str++)
kono
parents:
diff changeset
36 putchar (TOUPPER (*str));
kono
parents:
diff changeset
37 }
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 static void
kono
parents:
diff changeset
40 gen_attr (md_rtx_info *info)
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 const char *p, *tag;
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 rtx attr = info->def;
kono
parents:
diff changeset
45 p = XSTR (attr, 1);
kono
parents:
diff changeset
46 if (*p != '\0')
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 printf ("enum attr_%s {", XSTR (attr, 0));
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 while ((tag = scan_comma_elt (&p)) != 0)
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 write_upcase (XSTR (attr, 0));
kono
parents:
diff changeset
53 putchar ('_');
kono
parents:
diff changeset
54 while (tag != p)
kono
parents:
diff changeset
55 putchar (TOUPPER (*tag++));
kono
parents:
diff changeset
56 if (*p == ',')
kono
parents:
diff changeset
57 fputs (", ", stdout);
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59 fputs ("};\n", stdout);
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61 }
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 int
kono
parents:
diff changeset
64 main (int argc, const char **argv)
kono
parents:
diff changeset
65 {
kono
parents:
diff changeset
66 bool have_delay = false;
kono
parents:
diff changeset
67 bool have_sched = false;
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 progname = "genattr-common";
kono
parents:
diff changeset
70
kono
parents:
diff changeset
71 if (!init_rtx_reader_args (argc, argv))
kono
parents:
diff changeset
72 return (FATAL_EXIT_CODE);
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 puts ("/* Generated automatically by the program `genattr-common'");
kono
parents:
diff changeset
75 puts (" from the machine description file `md'. */\n");
kono
parents:
diff changeset
76 puts ("#ifndef GCC_INSN_ATTR_COMMON_H");
kono
parents:
diff changeset
77 puts ("#define GCC_INSN_ATTR_COMMON_H\n");
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 /* Read the machine description. */
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 md_rtx_info info;
kono
parents:
diff changeset
82 while (read_md_rtx (&info))
kono
parents:
diff changeset
83 switch (GET_CODE (info.def))
kono
parents:
diff changeset
84 {
kono
parents:
diff changeset
85 case DEFINE_ATTR:
kono
parents:
diff changeset
86 gen_attr (&info);
kono
parents:
diff changeset
87 break;
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 case DEFINE_DELAY:
kono
parents:
diff changeset
90 have_delay = true;
kono
parents:
diff changeset
91 break;
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 case DEFINE_INSN_RESERVATION:
kono
parents:
diff changeset
94 if (!have_sched)
kono
parents:
diff changeset
95 {
kono
parents:
diff changeset
96 printf ("#define INSN_SCHEDULING\n");
kono
parents:
diff changeset
97 have_sched = true;
kono
parents:
diff changeset
98 }
kono
parents:
diff changeset
99 break;
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 default:
kono
parents:
diff changeset
102 break;
kono
parents:
diff changeset
103 }
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 printf ("#define DELAY_SLOTS %d\n", have_delay);
kono
parents:
diff changeset
106 puts ("\n#endif /* GCC_INSN_ATTR_COMMON_H */");
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 if (ferror (stdout) || fflush (stdout) || fclose (stdout))
kono
parents:
diff changeset
109 return FATAL_EXIT_CODE;
kono
parents:
diff changeset
110
kono
parents:
diff changeset
111 return SUCCESS_EXIT_CODE;
kono
parents:
diff changeset
112 }