annotate gcc/config/mips/genopt.sh @ 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 #!/bin/sh
kono
parents:
diff changeset
2 # Generate mips-tables.opt from the list of CPUs in mips-cpus.def.
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
3 # Copyright (C) 2011-2018 Free Software Foundation, Inc.
111
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
kono
parents:
diff changeset
8 # it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
9 # the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
10 # any later version.
kono
parents:
diff changeset
11 #
kono
parents:
diff changeset
12 # GCC is distributed in the hope that it will be useful,
kono
parents:
diff changeset
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
15 # GNU General Public 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 cat <<EOF
kono
parents:
diff changeset
22 ; -*- buffer-read-only: t -*-
kono
parents:
diff changeset
23 ; Generated automatically by genopt.sh from mips-cpus.def.
kono
parents:
diff changeset
24
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
25 ; Copyright (C) 2011-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
26 ;
kono
parents:
diff changeset
27 ; This file is part of GCC.
kono
parents:
diff changeset
28 ;
kono
parents:
diff changeset
29 ; GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
30 ; the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
31 ; Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
32 ; version.
kono
parents:
diff changeset
33 ;
kono
parents:
diff changeset
34 ; GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
35 ; WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
36 ; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
37 ; for more details.
kono
parents:
diff changeset
38 ;
kono
parents:
diff changeset
39 ; You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
40 ; along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
41 ; <http://www.gnu.org/licenses/>.
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 Enum
kono
parents:
diff changeset
44 Name(mips_arch_opt_value) Type(int)
kono
parents:
diff changeset
45 Known MIPS CPUs (for use with the -march= and -mtune= options):
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 Enum
kono
parents:
diff changeset
48 Name(mips_mips_opt_value) Type(int)
kono
parents:
diff changeset
49 Known MIPS ISA levels (for use with the -mips option):
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 EnumValue
kono
parents:
diff changeset
52 Enum(mips_arch_opt_value) String(from-abi) Value(MIPS_ARCH_OPTION_FROM_ABI)
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 EnumValue
kono
parents:
diff changeset
55 Enum(mips_arch_opt_value) String(native) Value(MIPS_ARCH_OPTION_NATIVE) DriverOnly
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 EOF
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 awk -F'[(, ]+' '
kono
parents:
diff changeset
60 BEGIN {
kono
parents:
diff changeset
61 value = 0
kono
parents:
diff changeset
62 }
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 # Write an entry for a single string accepted as a -march= argument.
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 function write_one_arch_value(name, value, flags)
kono
parents:
diff changeset
67 {
kono
parents:
diff changeset
68 print "EnumValue"
kono
parents:
diff changeset
69 print "Enum(mips_arch_opt_value) String(" name ") Value(" value ")" flags
kono
parents:
diff changeset
70 print ""
kono
parents:
diff changeset
71 if (name ~ "^mips") {
kono
parents:
diff changeset
72 sub("^mips", "", name)
kono
parents:
diff changeset
73 print "EnumValue"
kono
parents:
diff changeset
74 print "Enum(mips_mips_opt_value) String(" name ") Value(" value ")"
kono
parents:
diff changeset
75 print ""
kono
parents:
diff changeset
76 }
kono
parents:
diff changeset
77 }
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 # The logic for matching CPU name variants should be the same as in GAS.
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 # Write an entry for a single string accepted as a -march= argument,
kono
parents:
diff changeset
82 # plus any variant with a final "000" replaced by "k".
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 function write_arch_value_maybe_k(name, value, flags)
kono
parents:
diff changeset
85 {
kono
parents:
diff changeset
86 write_one_arch_value(name, value, flags)
kono
parents:
diff changeset
87 if (name ~ "000$") {
kono
parents:
diff changeset
88 sub("000$", "k", name)
kono
parents:
diff changeset
89 write_one_arch_value(name, value, "")
kono
parents:
diff changeset
90 }
kono
parents:
diff changeset
91 }
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 # Write all the entries for a -march= argument. In addition to
kono
parents:
diff changeset
94 # replacement of a final "000" with "k", an argument starting with
kono
parents:
diff changeset
95 # "vr", "rm" or "r" followed by a number, or just a plain number,
kono
parents:
diff changeset
96 # matches a plain number or "r" followed by a plain number.
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 function write_all_arch_values(name, value)
kono
parents:
diff changeset
99 {
kono
parents:
diff changeset
100 write_arch_value_maybe_k(name, value, " Canonical")
kono
parents:
diff changeset
101 cname = name
kono
parents:
diff changeset
102 if (cname ~ "^vr") {
kono
parents:
diff changeset
103 sub("^vr", "", cname)
kono
parents:
diff changeset
104 } else if (cname ~ "^rm") {
kono
parents:
diff changeset
105 sub("^rm", "", cname)
kono
parents:
diff changeset
106 } else if (cname ~ "^r") {
kono
parents:
diff changeset
107 sub("^r", "", cname)
kono
parents:
diff changeset
108 }
kono
parents:
diff changeset
109 if (cname ~ "^[0-9]") {
kono
parents:
diff changeset
110 if (cname != name)
kono
parents:
diff changeset
111 write_arch_value_maybe_k(cname, value, "")
kono
parents:
diff changeset
112 rname = "r" cname
kono
parents:
diff changeset
113 if (rname != name)
kono
parents:
diff changeset
114 write_arch_value_maybe_k(rname, value, "")
kono
parents:
diff changeset
115 }
kono
parents:
diff changeset
116 }
kono
parents:
diff changeset
117
kono
parents:
diff changeset
118 /^MIPS_CPU/ {
kono
parents:
diff changeset
119 name = $2
kono
parents:
diff changeset
120 gsub("\"", "", name)
kono
parents:
diff changeset
121 write_all_arch_values(name, value)
kono
parents:
diff changeset
122 value++
kono
parents:
diff changeset
123 }' $1/mips-cpus.def