2 # $NetBSD: asm2gas,v 1.9 2008/03/28 22:27:33 apb Exp $
5 # Copyright (c) 1998,2008 The NetBSD Foundation, Inc.
8 # This code is derived from software contributed to The NetBSD Foundation
9 # by Charles M. Hannum.
11 # Redistribution and use in source and binary forms, with or without
12 # modification, are permitted provided that the following conditions
14 # 1. Redistributions of source code must retain the above copyright
15 # notice, this list of conditions and the following disclaimer.
16 # 2. Redistributions in binary form must reproduce the above copyright
17 # notice, this list of conditions and the following disclaimer in the
18 # documentation and/or other materials provided with the distribution.
20 # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
21 # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
22 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
24 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 # POSSIBILITY OF SUCH DAMAGE.
33 # This ugly script converts assembler code from Motorola's format to a
34 # form that gas (MIT syntax) can digest.
36 : ${SED:=sed} # Which sed to use
37 P
='%' # Prefix for register names, may be '%' or ''
39 cat "$1" |
"${SED}" -e '
40 # format canonicalization
42 # leave "#include" alone; change "#" and "*" comment lines to use "|".
46 /[ ]IDNT[ ]/{s/^/|/;p;d;}
49 s/\([A-Za-z_][A-Za-z0-9_]*\)[ ]*equ[ ]*/\1,/
50 s/[ ][ ]*\(.*\)$/ |\1/
55 s/^\([A-Za-z_][A-Za-z0-9_]*\)[ ][ ]*/\1: /
56 s/^\([A-Za-z_][A-Za-z0-9_]*\)$/\1:/
57 /^[A-Za-z_][A-Za-z0-9_]*:/{
65 /^[ ][ ]*\([.a-zA-Z][.a-zA-Z0-9]*\)/{
69 s/[ ][ ]*\(.*\)$/ |\1/
74 y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/
84 s/^ section 15/ .data/
85 /^ include/{s/include[ ]/.include "/;s/\.h[ ]*$/.defs"/;p;d;}
95 /^ add[aiqx]*\.[bwl] /{s/\.//;p;d;}
96 /^ andi*\.[bwl] /{s/\.//;p;d;}
97 /^ as[lr]\.[bwl] /{s/\.//;p;d;}
98 /^ clr\.[bwl] /{s/\.//;p;d;}
99 /^ cmp[i2]*\.[bwl] /{s/\.//;p;d;}
100 /^ eori*\.[bwl] /{s/\.//;p;d;}
101 /^ lea\.l /{s/\..//;p;d;}
102 /^ ls[lr]\.[bwl] /{s/\.//;p;d;}
103 /^ move[acmqs]*\.[bwl] /{s/\.//;p;d;}
104 /^ mul[su]\.[wl] /{s/\.//;p;d;}
105 /^ neg\.[bwl] /{s/\.//;p;d;}
106 /^ ori*\.[bwl] /{s/\.//;p;d;}
107 /^ ro[lrx]*\.[bwl] /{s/\.//;p;d;}
108 /^ sub[aiqx]*\.[bwl] /{s/\.//;p;d;}
109 /^ swap\.w /{s/\..//;p;d;}
110 /^ s\([a-tv-z][a-z]*\)\.b /{s/\..//;p;d;}
111 /^ tst\.[bwl] /{s/\.//;p;d;}
115 /^ bchg\.[bl] /{s/\..//;p;d;}
116 /^ bclr\.[bl] /{s/\..//;p;d;}
117 /^ bset\.[bl] /{s/\..//;p;d;}
118 /^ btst\.[bl] /{s/\..//;p;d;}
119 /^ div[sul]*\.[wl] /{s/\.//;p;d;}
120 /^ fabs\.[sdx] /{s/\.//;p;d;}
121 /^ fadd\.[sdxbwl] /{s/\.//;p;d;}
122 /^ fcmp\.[sdxbwl] /{s/\.//;p;d;}
123 /^ fdiv\.[sdx] /{s/\.//;p;d;}
124 /^ fmove[mx]*\.[sdxbwl] /{s/\.//;p;d;}
125 /^ fmul\.[sdx] /{s/\.//;p;d;}
126 /^ fneg\.[sdx] /{s/\.//;p;d;}
127 /^ fsqrt\.[sdx] /{s/\.//;p;d;}
128 /^ fsub\.[sdxbwl] /{s/\.//;p;d;}
129 /^ ftst\.[sdx] /{s/\.//;p;d;}
131 /^ b[a-eg-z][a-z]*\.b /{s/\.b/s/;p;d;}
132 /^ b[a-eg-z][a-z]*\.w /{s/\.w//;p;d;}
133 /^ b[a-eg-z][a-z]*\.l /{s/\.l/l/;p;d;}
134 /^ db[a-z][a-z]*\.w /{s/\.w//;p;d;}
135 /^ fb[a-eg-z][a-z]*\.w /{s/\.w//;p;d;}
136 /^ fb[a-eg-z][a-z]*\.l /{s/\.l/l/;p;d;}
140 # register names "FPIAR" -> "%FPI", etc., possibly without the "%"
141 s/\([^_a-zA-Z0-9]\)FPIAR\([^_a-zA-Z0-9]\)/\1'"$P"'FPI\2/g
142 s/\([^_a-zA-Z0-9]\)FPIAR$/\1'"$P"'FPI/g
143 s/\([^_a-zA-Z0-9]\)fpiar\([^_a-zA-Z0-9]\)/\1'"$P"'fpi\2/g
144 s/\([^_a-zA-Z0-9]\)fpiar$/\1'"$P"'fpi/g
145 s/\([^_a-zA-Z0-9]\)FPCR\([^_a-zA-Z0-9]\)/\1'"$P"'FPCR\2/g
146 s/\([^_a-zA-Z0-9]\)FPCR$/\1'"$P"'FPCR/g
147 s/\([^_a-zA-Z0-9]\)fpcr\([^_a-zA-Z0-9]\)/\1'"$P"'fpcr\2/g
148 s/\([^_a-zA-Z0-9]\)fpcr$/\1'"$P"'fpcr/g
149 s/\([^_a-zA-Z0-9]\)FPSR\([^_a-zA-Z0-9]\)/\1'"$P"'FPSR\2/g
150 s/\([^_a-zA-Z0-9]\)FPSR$/\1'"$P"'FPSR/g
151 s/\([^_a-zA-Z0-9]\)fpsr\([^_a-zA-Z0-9]\)/\1'"$P"'fpsr\2/g
152 s/\([^_a-zA-Z0-9]\)fpsr$/\1'"$P"'fpsr/g
154 # Hexadecimal numbers
155 s/\$\([0-9a-fA-F]\)/0x\1/g
158 # Insert "%" before more register names (only if $P = "%").
159 # Some of the rules are repeated because of overlap between trailing
160 # context in one match and leading context in another match; otherwise
161 # only half the register names in "d4{d3:4},d0" would be converted.
162 s/\([^[:alnum:]_%]\)\([dDaA][0-7]\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
163 s/\([^[:alnum:]_%]\)\([fF][pP][0-7]\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
164 s/\([^[:alnum:]_%]\)\(sp\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
165 s/\([^[:alnum:]_%]\)\(pc\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
167 s/\([^[:alnum:]_%]\)\([dDaA][0-7]\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
168 s/\([^[:alnum:]_%]\)\([fF][pP][0-7]\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
169 s/\([^[:alnum:]_%]\)\(sp\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
170 s/\([^[:alnum:]_%]\)\(pc\)\([^[:alnum:]_]\)/\1'"$P"'\2\3/g
172 s/\([^[:alnum:]_%]\)\([dDaA][0-7]\)$/\1'"$P"'\2/g
173 s/\([^[:alnum:]_%]\)\([dDaA][0-7]\)$/\1'"$P"'\2/g
174 s/\([^[:alnum:]_%]\)\([fF][pP][0-7]\)$/\1'"$P"'\2/g
175 s/\([^[:alnum:]_%]\)\(sp\)$/\1'"$P"'\2/g
177 s/\(,\)\([dDaA][0-7]\)/\1'"$P"'\2/g
178 s/\(,\)\([fF][pP][0-7]\)/\1'"$P"'\2/g
180 # "-(%sp)" -> "%sp@-", etc. (possibly without the "%")
181 s/-(\('"$P"'[sSpPaA][pPcC0-7]\))/\1@-/g
182 # "(%sp)+" -> "%sp@+", etc. (possibly without the "%")
183 s/(\('"$P"'[sSpPaA][pPcC0-7]\))+/\1@+/g
184 # "foo(%sp,...)" -> "%sp@(foo,...)", etc. (possibly without the "%")
185 s/\([-+A-Za-z0-9_]*\)(\('"$P"'[sSpPaA][pPcC0-7]\)\([),]\)/\2@(\1\3/g
187 # ".w" -> ":w"; ".w*nn" -> ":w:nn"; "*nn" -> ":l:nn"; etc.
188 s/\.\([bBwWlL])\)/:\1/g
189 s/\.\([bBwWlL]\)\*\([0-9][0-9]*)\)/:\1:\2/g
190 s/\*\([0-9][0-9]*\))/:l:\1)/g
191 # "{nn:mm}" -> "{#nn:#mm}"
192 s/{\([0-9][0-9]*\):\([0-9][0-9]*\)}/{#\1:#\2}/g
193 # "{%d0:nn}" -> "{%d0:#nn}", etc. (possibly without the "%")
194 s/{\('"$P"'[dD][0-7]\):\([0-9][0-9]*\)}/{\1:#\2}/g
196 # Remove empty "()" or "(0)" after "@"
198 # Remove leading "," or trailing ":" in parentheses
201 # make up for a gas bug
203 s/ \('"$P"'[fF][pP][0-7]\),/ \1-\1,/
204 s/,\('"$P"'[fF][pP][0-7]\) /,\1-\1 /
205 s/,\('"$P"'[fF][pP][0-7]\)$/,\1-\1/
208 # Floating point literal conversion
210 s/:0x41dfffffffc00000/0r2147483647.0/g
211 s/:0xc1e0000000000000/0r-2147483648.0/g
212 s/:0x41dfffffffe00000/0r2147483647.5/g
213 s/:0xc1e0000000100000/0r-2147483648.5/g
214 s/:0x46fffe00/0r32767.0/g
215 s/:0xc7000000/0r-32768.0/g
216 s/:0x46ffff00/0r32767.5/g
217 s/:0xc7000080/0r-32768.5/g
218 s/:0x42fe0000/0r127.0/g
219 s/:0xc3000000/0r-128.0/g
220 s/:0x42ff0000/0r127.5/g
221 s/:0xc3008000/0r-128.5/g
222 s/:0x3F800000/0r1.0/g
223 s/:0x00000000/0r0.0/g
224 s/:0xBF800000/0r-1.0/g
225 s/:0x3F000000/0r0.5/g
226 s/:0x3E800000/0r0.25/g
227 s/:0x42B8AA3B/0r92.332481384277343750/g
228 s/:0xBC317218/0r-0.0108304247260093688964843750/g
229 s/:0x3AB60B70/0r0.001388890668749809265136718750/g
230 s/:0x3C088895/0r0.0083333449438214302062988281250/g
231 s/:0x42B8AA3B/0r92.332481384277343750/g
232 s/:0x3950097B/0r0.0001983995753107592463493347167968750/g
233 s/:0x3AB60B6A/0r0.001388889970257878303527832031250/g
234 s/:0x2F30CAA8/0r1.60791047143504783889511600136756896972656250e-10/g
235 s/:0x310F8290/0r2.0883454965314740547910332679748535156250e-09/g
236 s/:0x32D73220/0r2.5052088403754169121384620666503906250e-08/g
237 s/:0x3493F281/0r2.755732850800995947793126106262207031250e-07/g
238 s/:0x40000000/0r2.0/g
239 s/:0x42800000/0r6.40e+01/g
240 s/:0x3C800000/0r1.56250e-02/g
241 s/fadds #:0x00800000,'"$P"'[fF][pP]0/ .long 0xf23c4422,0x00800000/
242 s/fsubs #:0x00800000,'"$P"'[fF][pP]0/ .long 0xf23c4428,0x00800000/
243 s/fsubs #:0x00800000,'"$P"'[fF][pP]1/ .long 0xf23c44a8,0x00800000/
244 s/fmoves #:0x80000000,'"$P"'[fF][pP]0/ .long 0xf23c4400,0x80000000/
245 s/fmoves #:0x00000000,'"$P"'[fF][pP]0/ .long 0xf23c4400,0x00000000/