power6.md revision 1.1 1 1.1 mrg ;; Scheduling description for IBM POWER6 processor.
2 1.1 mrg ;; Copyright (C) 2006, 2007, 2009 Free Software Foundation, Inc.
3 1.1 mrg ;; Contributed by Peter Steinmetz (steinmtz (a] us.ibm.com)
4 1.1 mrg ;;
5 1.1 mrg ;; This file is part of GCC.
6 1.1 mrg ;;
7 1.1 mrg ;; GCC is free software; you can redistribute it and/or modify it
8 1.1 mrg ;; under the terms of the GNU General Public License as published
9 1.1 mrg ;; by the Free Software Foundation; either version 3, or (at your
10 1.1 mrg ;; option) any later version.
11 1.1 mrg ;;
12 1.1 mrg ;; GCC is distributed in the hope that it will be useful, but WITHOUT
13 1.1 mrg ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 1.1 mrg ;; or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
15 1.1 mrg ;; License for more details.
16 1.1 mrg ;;
17 1.1 mrg ;; You should have received a copy of the GNU General Public License
18 1.1 mrg ;; along with GCC; see the file COPYING3. If not see
19 1.1 mrg ;; <http://www.gnu.org/licenses/>.
20 1.1 mrg
21 1.1 mrg ;; Sources:
22 1.1 mrg
23 1.1 mrg ;; The POWER6 has 2 iu, 2 fpu, 2 lsu, and 1 bu/cru unit per engine
24 1.1 mrg ;; (2 engines per chip). The chip can issue up to 5 internal ops
25 1.1 mrg ;; per cycle.
26 1.1 mrg
27 1.1 mrg (define_automaton "power6iu,power6lsu,power6fpu,power6bu")
28 1.1 mrg
29 1.1 mrg (define_cpu_unit "iu1_power6,iu2_power6" "power6iu")
30 1.1 mrg (define_cpu_unit "lsu1_power6,lsu2_power6" "power6lsu")
31 1.1 mrg (define_cpu_unit "bpu_power6" "power6bu")
32 1.1 mrg (define_cpu_unit "fpu1_power6,fpu2_power6" "power6fpu")
33 1.1 mrg
34 1.1 mrg (define_reservation "LS2_power6"
35 1.1 mrg "lsu1_power6+lsu2_power6")
36 1.1 mrg
37 1.1 mrg (define_reservation "FPU_power6"
38 1.1 mrg "fpu1_power6|fpu2_power6")
39 1.1 mrg
40 1.1 mrg (define_reservation "BRU_power6"
41 1.1 mrg "bpu_power6")
42 1.1 mrg
43 1.1 mrg (define_reservation "LSU_power6"
44 1.1 mrg "lsu1_power6|lsu2_power6")
45 1.1 mrg
46 1.1 mrg (define_reservation "LSF_power6"
47 1.1 mrg "(lsu1_power6+fpu1_power6)\
48 1.1 mrg |(lsu1_power6+fpu2_power6)\
49 1.1 mrg |(lsu2_power6+fpu1_power6)\
50 1.1 mrg |(lsu2_power6+fpu2_power6)")
51 1.1 mrg
52 1.1 mrg (define_reservation "LX2_power6"
53 1.1 mrg "(iu1_power6+iu2_power6+lsu1_power6)\
54 1.1 mrg |(iu1_power6+iu2_power6+lsu2_power6)")
55 1.1 mrg
56 1.1 mrg (define_reservation "FX2_power6"
57 1.1 mrg "iu1_power6+iu2_power6")
58 1.1 mrg
59 1.1 mrg (define_reservation "X2F_power6"
60 1.1 mrg "(iu1_power6+iu2_power6+fpu1_power6)\
61 1.1 mrg |(iu1_power6+iu2_power6+fpu2_power6)")
62 1.1 mrg
63 1.1 mrg (define_reservation "BX2_power6"
64 1.1 mrg "iu1_power6+iu2_power6+bpu_power6")
65 1.1 mrg
66 1.1 mrg (define_reservation "LSX_power6"
67 1.1 mrg "(iu1_power6+lsu1_power6)\
68 1.1 mrg |(iu1_power6+lsu2_power6)\
69 1.1 mrg |(iu2_power6+lsu1_power6)\
70 1.1 mrg |(iu2_power6+lsu2_power6)")
71 1.1 mrg
72 1.1 mrg (define_reservation "FXU_power6"
73 1.1 mrg "iu1_power6|iu2_power6")
74 1.1 mrg
75 1.1 mrg (define_reservation "XLF_power6"
76 1.1 mrg "(iu1_power6+lsu1_power6+fpu1_power6)\
77 1.1 mrg |(iu1_power6+lsu1_power6+fpu2_power6)\
78 1.1 mrg |(iu1_power6+lsu2_power6+fpu1_power6)\
79 1.1 mrg |(iu1_power6+lsu2_power6+fpu2_power6)\
80 1.1 mrg |(iu2_power6+lsu1_power6+fpu1_power6)\
81 1.1 mrg |(iu2_power6+lsu1_power6+fpu2_power6)\
82 1.1 mrg |(iu2_power6+lsu2_power6+fpu1_power6)\
83 1.1 mrg |(iu2_power6+lsu2_power6+fpu2_power6)")
84 1.1 mrg
85 1.1 mrg (define_reservation "BRX_power6"
86 1.1 mrg "(bpu_power6+iu1_power6)\
87 1.1 mrg |(bpu_power6+iu2_power6)")
88 1.1 mrg
89 1.1 mrg ; Load/store
90 1.1 mrg
91 1.1 mrg ; The default for a value written by a fixed point load
92 1.1 mrg ; that is read/written by a subsequent fixed point op.
93 1.1 mrg (define_insn_reservation "power6-load" 2 ; fx
94 1.1 mrg (and (eq_attr "type" "load")
95 1.1 mrg (eq_attr "cpu" "power6"))
96 1.1 mrg "LSU_power6")
97 1.1 mrg
98 1.1 mrg ; define the bypass for the case where the value written
99 1.1 mrg ; by a fixed point load is used as the source value on
100 1.1 mrg ; a store.
101 1.1 mrg (define_bypass 1 "power6-load,\
102 1.1 mrg power6-load-update,\
103 1.1 mrg power6-load-update-indexed"
104 1.1 mrg "power6-store,\
105 1.1 mrg power6-store-update,\
106 1.1 mrg power6-store-update-indexed,\
107 1.1 mrg power6-fpstore,\
108 1.1 mrg power6-fpstore-update"
109 1.1 mrg "store_data_bypass_p")
110 1.1 mrg
111 1.1 mrg (define_insn_reservation "power6-load-ext" 4 ; fx
112 1.1 mrg (and (eq_attr "type" "load_ext")
113 1.1 mrg (eq_attr "cpu" "power6"))
114 1.1 mrg "LSU_power6")
115 1.1 mrg
116 1.1 mrg ; define the bypass for the case where the value written
117 1.1 mrg ; by a fixed point load ext is used as the source value on
118 1.1 mrg ; a store.
119 1.1 mrg (define_bypass 1 "power6-load-ext,\
120 1.1 mrg power6-load-ext-update,\
121 1.1 mrg power6-load-ext-update-indexed"
122 1.1 mrg "power6-store,\
123 1.1 mrg power6-store-update,\
124 1.1 mrg power6-store-update-indexed,\
125 1.1 mrg power6-fpstore,\
126 1.1 mrg power6-fpstore-update"
127 1.1 mrg "store_data_bypass_p")
128 1.1 mrg
129 1.1 mrg (define_insn_reservation "power6-load-update" 2 ; fx
130 1.1 mrg (and (eq_attr "type" "load_u")
131 1.1 mrg (eq_attr "cpu" "power6"))
132 1.1 mrg "LSX_power6")
133 1.1 mrg
134 1.1 mrg (define_insn_reservation "power6-load-update-indexed" 2 ; fx
135 1.1 mrg (and (eq_attr "type" "load_ux")
136 1.1 mrg (eq_attr "cpu" "power6"))
137 1.1 mrg "LSX_power6")
138 1.1 mrg
139 1.1 mrg (define_insn_reservation "power6-load-ext-update" 4 ; fx
140 1.1 mrg (and (eq_attr "type" "load_ext_u")
141 1.1 mrg (eq_attr "cpu" "power6"))
142 1.1 mrg "LSX_power6")
143 1.1 mrg
144 1.1 mrg (define_insn_reservation "power6-load-ext-update-indexed" 4 ; fx
145 1.1 mrg (and (eq_attr "type" "load_ext_ux")
146 1.1 mrg (eq_attr "cpu" "power6"))
147 1.1 mrg "LSX_power6")
148 1.1 mrg
149 1.1 mrg (define_insn_reservation "power6-fpload" 1
150 1.1 mrg (and (eq_attr "type" "fpload")
151 1.1 mrg (eq_attr "cpu" "power6"))
152 1.1 mrg "LSU_power6")
153 1.1 mrg
154 1.1 mrg (define_insn_reservation "power6-fpload-update" 1
155 1.1 mrg (and (eq_attr "type" "fpload_u,fpload_ux")
156 1.1 mrg (eq_attr "cpu" "power6"))
157 1.1 mrg "LSX_power6")
158 1.1 mrg
159 1.1 mrg (define_insn_reservation "power6-store" 14
160 1.1 mrg (and (eq_attr "type" "store")
161 1.1 mrg (eq_attr "cpu" "power6"))
162 1.1 mrg "LSU_power6")
163 1.1 mrg
164 1.1 mrg (define_insn_reservation "power6-store-update" 14
165 1.1 mrg (and (eq_attr "type" "store_u")
166 1.1 mrg (eq_attr "cpu" "power6"))
167 1.1 mrg "LSX_power6")
168 1.1 mrg
169 1.1 mrg (define_insn_reservation "power6-store-update-indexed" 14
170 1.1 mrg (and (eq_attr "type" "store_ux")
171 1.1 mrg (eq_attr "cpu" "power6"))
172 1.1 mrg "LX2_power6")
173 1.1 mrg
174 1.1 mrg (define_insn_reservation "power6-fpstore" 14
175 1.1 mrg (and (eq_attr "type" "fpstore")
176 1.1 mrg (eq_attr "cpu" "power6"))
177 1.1 mrg "LSF_power6")
178 1.1 mrg
179 1.1 mrg (define_insn_reservation "power6-fpstore-update" 14
180 1.1 mrg (and (eq_attr "type" "fpstore_u,fpstore_ux")
181 1.1 mrg (eq_attr "cpu" "power6"))
182 1.1 mrg "XLF_power6")
183 1.1 mrg
184 1.1 mrg (define_insn_reservation "power6-larx" 3
185 1.1 mrg (and (eq_attr "type" "load_l")
186 1.1 mrg (eq_attr "cpu" "power6"))
187 1.1 mrg "LS2_power6")
188 1.1 mrg
189 1.1 mrg (define_insn_reservation "power6-stcx" 10 ; best case
190 1.1 mrg (and (eq_attr "type" "store_c")
191 1.1 mrg (eq_attr "cpu" "power6"))
192 1.1 mrg "LSX_power6")
193 1.1 mrg
194 1.1 mrg (define_insn_reservation "power6-sync" 11 ; N/A
195 1.1 mrg (and (eq_attr "type" "sync")
196 1.1 mrg (eq_attr "cpu" "power6"))
197 1.1 mrg "LSU_power6")
198 1.1 mrg
199 1.1 mrg (define_insn_reservation "power6-integer" 1
200 1.1 mrg (and (eq_attr "type" "integer")
201 1.1 mrg (eq_attr "cpu" "power6"))
202 1.1 mrg "FXU_power6")
203 1.1 mrg
204 1.1 mrg (define_insn_reservation "power6-isel" 1
205 1.1 mrg (and (eq_attr "type" "isel")
206 1.1 mrg (eq_attr "cpu" "power6"))
207 1.1 mrg "FXU_power6")
208 1.1 mrg
209 1.1 mrg (define_insn_reservation "power6-exts" 1
210 1.1 mrg (and (eq_attr "type" "exts")
211 1.1 mrg (eq_attr "cpu" "power6"))
212 1.1 mrg "FXU_power6")
213 1.1 mrg
214 1.1 mrg (define_insn_reservation "power6-shift" 1
215 1.1 mrg (and (eq_attr "type" "shift")
216 1.1 mrg (eq_attr "cpu" "power6"))
217 1.1 mrg "FXU_power6")
218 1.1 mrg
219 1.1 mrg (define_insn_reservation "power6-insert" 1
220 1.1 mrg (and (eq_attr "type" "insert_word")
221 1.1 mrg (eq_attr "cpu" "power6"))
222 1.1 mrg "FX2_power6")
223 1.1 mrg
224 1.1 mrg (define_insn_reservation "power6-insert-dword" 1
225 1.1 mrg (and (eq_attr "type" "insert_dword")
226 1.1 mrg (eq_attr "cpu" "power6"))
227 1.1 mrg "FX2_power6")
228 1.1 mrg
229 1.1 mrg ; define the bypass for the case where the value written
230 1.1 mrg ; by a fixed point op is used as the source value on a
231 1.1 mrg ; store.
232 1.1 mrg (define_bypass 1 "power6-integer,\
233 1.1 mrg power6-exts,\
234 1.1 mrg power6-shift,\
235 1.1 mrg power6-insert,\
236 1.1 mrg power6-insert-dword"
237 1.1 mrg "power6-store,\
238 1.1 mrg power6-store-update,\
239 1.1 mrg power6-store-update-indexed,\
240 1.1 mrg power6-fpstore,\
241 1.1 mrg power6-fpstore-update"
242 1.1 mrg "store_data_bypass_p")
243 1.1 mrg
244 1.1 mrg (define_insn_reservation "power6-cntlz" 2
245 1.1 mrg (and (eq_attr "type" "cntlz")
246 1.1 mrg (eq_attr "cpu" "power6"))
247 1.1 mrg "FXU_power6")
248 1.1 mrg
249 1.1 mrg (define_bypass 1 "power6-cntlz"
250 1.1 mrg "power6-store,\
251 1.1 mrg power6-store-update,\
252 1.1 mrg power6-store-update-indexed,\
253 1.1 mrg power6-fpstore,\
254 1.1 mrg power6-fpstore-update"
255 1.1 mrg "store_data_bypass_p")
256 1.1 mrg
257 1.1 mrg (define_insn_reservation "power6-var-rotate" 4
258 1.1 mrg (and (eq_attr "type" "var_shift_rotate")
259 1.1 mrg (eq_attr "cpu" "power6"))
260 1.1 mrg "FXU_power6")
261 1.1 mrg
262 1.1 mrg (define_insn_reservation "power6-trap" 1 ; N/A
263 1.1 mrg (and (eq_attr "type" "trap")
264 1.1 mrg (eq_attr "cpu" "power6"))
265 1.1 mrg "BRX_power6")
266 1.1 mrg
267 1.1 mrg (define_insn_reservation "power6-two" 1
268 1.1 mrg (and (eq_attr "type" "two")
269 1.1 mrg (eq_attr "cpu" "power6"))
270 1.1 mrg "(iu1_power6,iu1_power6)\
271 1.1 mrg |(iu1_power6+iu2_power6,nothing)\
272 1.1 mrg |(iu1_power6,iu2_power6)\
273 1.1 mrg |(iu2_power6,iu1_power6)\
274 1.1 mrg |(iu2_power6,iu2_power6)")
275 1.1 mrg
276 1.1 mrg (define_insn_reservation "power6-three" 1
277 1.1 mrg (and (eq_attr "type" "three")
278 1.1 mrg (eq_attr "cpu" "power6"))
279 1.1 mrg "(iu1_power6,iu1_power6,iu1_power6)\
280 1.1 mrg |(iu1_power6,iu1_power6,iu2_power6)\
281 1.1 mrg |(iu1_power6,iu2_power6,iu1_power6)\
282 1.1 mrg |(iu1_power6,iu2_power6,iu2_power6)\
283 1.1 mrg |(iu2_power6,iu1_power6,iu1_power6)\
284 1.1 mrg |(iu2_power6,iu1_power6,iu2_power6)\
285 1.1 mrg |(iu2_power6,iu2_power6,iu1_power6)\
286 1.1 mrg |(iu2_power6,iu2_power6,iu2_power6)\
287 1.1 mrg |(iu1_power6+iu2_power6,iu1_power6)\
288 1.1 mrg |(iu1_power6+iu2_power6,iu2_power6)\
289 1.1 mrg |(iu1_power6,iu1_power6+iu2_power6)\
290 1.1 mrg |(iu2_power6,iu1_power6+iu2_power6)")
291 1.1 mrg
292 1.1 mrg (define_insn_reservation "power6-cmp" 1
293 1.1 mrg (and (eq_attr "type" "cmp")
294 1.1 mrg (eq_attr "cpu" "power6"))
295 1.1 mrg "FXU_power6")
296 1.1 mrg
297 1.1 mrg (define_insn_reservation "power6-compare" 1
298 1.1 mrg (and (eq_attr "type" "compare")
299 1.1 mrg (eq_attr "cpu" "power6"))
300 1.1 mrg "FXU_power6")
301 1.1 mrg
302 1.1 mrg (define_insn_reservation "power6-fast-compare" 1
303 1.1 mrg (and (eq_attr "type" "fast_compare")
304 1.1 mrg (eq_attr "cpu" "power6"))
305 1.1 mrg "FXU_power6")
306 1.1 mrg
307 1.1 mrg ; define the bypass for the case where the value written
308 1.1 mrg ; by a fixed point rec form op is used as the source value
309 1.1 mrg ; on a store.
310 1.1 mrg (define_bypass 1 "power6-compare,\
311 1.1 mrg power6-fast-compare"
312 1.1 mrg "power6-store,\
313 1.1 mrg power6-store-update,\
314 1.1 mrg power6-store-update-indexed,\
315 1.1 mrg power6-fpstore,\
316 1.1 mrg power6-fpstore-update"
317 1.1 mrg "store_data_bypass_p")
318 1.1 mrg
319 1.1 mrg (define_insn_reservation "power6-delayed-compare" 2 ; N/A
320 1.1 mrg (and (eq_attr "type" "delayed_compare")
321 1.1 mrg (eq_attr "cpu" "power6"))
322 1.1 mrg "FXU_power6")
323 1.1 mrg
324 1.1 mrg (define_insn_reservation "power6-var-delayed-compare" 4
325 1.1 mrg (and (eq_attr "type" "var_delayed_compare")
326 1.1 mrg (eq_attr "cpu" "power6"))
327 1.1 mrg "FXU_power6")
328 1.1 mrg
329 1.1 mrg (define_insn_reservation "power6-lmul-cmp" 16
330 1.1 mrg (and (eq_attr "type" "lmul_compare")
331 1.1 mrg (eq_attr "cpu" "power6"))
332 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
333 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
334 1.1 mrg
335 1.1 mrg (define_insn_reservation "power6-imul-cmp" 16
336 1.1 mrg (and (eq_attr "type" "imul_compare")
337 1.1 mrg (eq_attr "cpu" "power6"))
338 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
339 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
340 1.1 mrg
341 1.1 mrg (define_insn_reservation "power6-lmul" 16
342 1.1 mrg (and (eq_attr "type" "lmul")
343 1.1 mrg (eq_attr "cpu" "power6"))
344 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
345 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
346 1.1 mrg
347 1.1 mrg (define_insn_reservation "power6-imul" 16
348 1.1 mrg (and (eq_attr "type" "imul")
349 1.1 mrg (eq_attr "cpu" "power6"))
350 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
351 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
352 1.1 mrg
353 1.1 mrg (define_insn_reservation "power6-imul3" 16
354 1.1 mrg (and (eq_attr "type" "imul2,imul3")
355 1.1 mrg (eq_attr "cpu" "power6"))
356 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
357 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
358 1.1 mrg
359 1.1 mrg (define_bypass 9 "power6-imul,\
360 1.1 mrg power6-lmul,\
361 1.1 mrg power6-imul-cmp,\
362 1.1 mrg power6-lmul-cmp,\
363 1.1 mrg power6-imul3"
364 1.1 mrg "power6-store,\
365 1.1 mrg power6-store-update,\
366 1.1 mrg power6-store-update-indexed,\
367 1.1 mrg power6-fpstore,\
368 1.1 mrg power6-fpstore-update"
369 1.1 mrg "store_data_bypass_p")
370 1.1 mrg
371 1.1 mrg (define_insn_reservation "power6-idiv" 44
372 1.1 mrg (and (eq_attr "type" "idiv")
373 1.1 mrg (eq_attr "cpu" "power6"))
374 1.1 mrg "(iu1_power6*44+iu2_power6*44+fpu1_power6*44)\
375 1.1 mrg |(iu1_power6*44+iu2_power6*44+fpu2_power6*44)");
376 1.1 mrg
377 1.1 mrg ; The latency for this bypass is yet to be defined
378 1.1 mrg ;(define_bypass ? "power6-idiv"
379 1.1 mrg ; "power6-store,\
380 1.1 mrg ; power6-store-update,\
381 1.1 mrg ; power6-store-update-indexed,\
382 1.1 mrg ; power6-fpstore,\
383 1.1 mrg ; power6-fpstore-update"
384 1.1 mrg ; "store_data_bypass_p")
385 1.1 mrg
386 1.1 mrg (define_insn_reservation "power6-ldiv" 56
387 1.1 mrg (and (eq_attr "type" "ldiv")
388 1.1 mrg (eq_attr "cpu" "power6"))
389 1.1 mrg "(iu1_power6*56+iu2_power6*56+fpu1_power6*56)\
390 1.1 mrg |(iu1_power6*56+iu2_power6*56+fpu2_power6*56)");
391 1.1 mrg
392 1.1 mrg ; The latency for this bypass is yet to be defined
393 1.1 mrg ;(define_bypass ? "power6-ldiv"
394 1.1 mrg ; "power6-store,\
395 1.1 mrg ; power6-store-update,\
396 1.1 mrg ; power6-store-update-indexed,\
397 1.1 mrg ; power6-fpstore,\
398 1.1 mrg ; power6-fpstore-update"
399 1.1 mrg ; "store_data_bypass_p")
400 1.1 mrg
401 1.1 mrg (define_insn_reservation "power6-mtjmpr" 2
402 1.1 mrg (and (eq_attr "type" "mtjmpr,mfjmpr")
403 1.1 mrg (eq_attr "cpu" "power6"))
404 1.1 mrg "BX2_power6")
405 1.1 mrg
406 1.1 mrg (define_bypass 5 "power6-mtjmpr" "power6-branch")
407 1.1 mrg
408 1.1 mrg (define_insn_reservation "power6-branch" 2
409 1.1 mrg (and (eq_attr "type" "jmpreg,branch")
410 1.1 mrg (eq_attr "cpu" "power6"))
411 1.1 mrg "BRU_power6")
412 1.1 mrg
413 1.1 mrg (define_bypass 5 "power6-branch" "power6-mtjmpr")
414 1.1 mrg
415 1.1 mrg (define_insn_reservation "power6-crlogical" 3
416 1.1 mrg (and (eq_attr "type" "cr_logical")
417 1.1 mrg (eq_attr "cpu" "power6"))
418 1.1 mrg "BRU_power6")
419 1.1 mrg
420 1.1 mrg (define_bypass 3 "power6-crlogical" "power6-branch")
421 1.1 mrg
422 1.1 mrg (define_insn_reservation "power6-delayedcr" 3
423 1.1 mrg (and (eq_attr "type" "delayed_cr")
424 1.1 mrg (eq_attr "cpu" "power6"))
425 1.1 mrg "BRU_power6")
426 1.1 mrg
427 1.1 mrg (define_insn_reservation "power6-mfcr" 6 ; N/A
428 1.1 mrg (and (eq_attr "type" "mfcr")
429 1.1 mrg (eq_attr "cpu" "power6"))
430 1.1 mrg "BX2_power6")
431 1.1 mrg
432 1.1 mrg ; mfcrf (1 field)
433 1.1 mrg (define_insn_reservation "power6-mfcrf" 3 ; N/A
434 1.1 mrg (and (eq_attr "type" "mfcrf")
435 1.1 mrg (eq_attr "cpu" "power6"))
436 1.1 mrg "BX2_power6") ;
437 1.1 mrg
438 1.1 mrg ; mtcrf (1 field)
439 1.1 mrg (define_insn_reservation "power6-mtcr" 4 ; N/A
440 1.1 mrg (and (eq_attr "type" "mtcr")
441 1.1 mrg (eq_attr "cpu" "power6"))
442 1.1 mrg "BX2_power6")
443 1.1 mrg
444 1.1 mrg (define_bypass 9 "power6-mtcr" "power6-branch")
445 1.1 mrg
446 1.1 mrg (define_insn_reservation "power6-fp" 6
447 1.1 mrg (and (eq_attr "type" "fp,dmul")
448 1.1 mrg (eq_attr "cpu" "power6"))
449 1.1 mrg "FPU_power6")
450 1.1 mrg
451 1.1 mrg ; Any fp instruction that updates a CR has a latency
452 1.1 mrg ; of 6 to a dependent branch
453 1.1 mrg (define_bypass 6 "power6-fp" "power6-branch")
454 1.1 mrg
455 1.1 mrg (define_bypass 1 "power6-fp"
456 1.1 mrg "power6-fpstore,power6-fpstore-update"
457 1.1 mrg "store_data_bypass_p")
458 1.1 mrg
459 1.1 mrg (define_insn_reservation "power6-fpcompare" 8
460 1.1 mrg (and (eq_attr "type" "fpcompare")
461 1.1 mrg (eq_attr "cpu" "power6"))
462 1.1 mrg "FPU_power6")
463 1.1 mrg
464 1.1 mrg (define_bypass 12 "power6-fpcompare"
465 1.1 mrg "power6-branch,power6-crlogical")
466 1.1 mrg
467 1.1 mrg (define_insn_reservation "power6-sdiv" 26
468 1.1 mrg (and (eq_attr "type" "sdiv")
469 1.1 mrg (eq_attr "cpu" "power6"))
470 1.1 mrg "FPU_power6")
471 1.1 mrg
472 1.1 mrg (define_insn_reservation "power6-ddiv" 32
473 1.1 mrg (and (eq_attr "type" "ddiv")
474 1.1 mrg (eq_attr "cpu" "power6"))
475 1.1 mrg "FPU_power6")
476 1.1 mrg
477 1.1 mrg (define_insn_reservation "power6-sqrt" 30
478 1.1 mrg (and (eq_attr "type" "ssqrt")
479 1.1 mrg (eq_attr "cpu" "power6"))
480 1.1 mrg "FPU_power6")
481 1.1 mrg
482 1.1 mrg (define_insn_reservation "power6-dsqrt" 42
483 1.1 mrg (and (eq_attr "type" "dsqrt")
484 1.1 mrg (eq_attr "cpu" "power6"))
485 1.1 mrg "FPU_power6")
486 1.1 mrg
487 1.1 mrg (define_insn_reservation "power6-isync" 2 ; N/A
488 1.1 mrg (and (eq_attr "type" "isync")
489 1.1 mrg (eq_attr "cpu" "power6"))
490 1.1 mrg "FXU_power6")
491 1.1 mrg
492 1.1 mrg (define_insn_reservation "power6-vecload" 1
493 1.1 mrg (and (eq_attr "type" "vecload")
494 1.1 mrg (eq_attr "cpu" "power6"))
495 1.1 mrg "LSU_power6")
496 1.1 mrg
497 1.1 mrg (define_insn_reservation "power6-vecstore" 1
498 1.1 mrg (and (eq_attr "type" "vecstore")
499 1.1 mrg (eq_attr "cpu" "power6"))
500 1.1 mrg "LSF_power6")
501 1.1 mrg
502 1.1 mrg (define_insn_reservation "power6-vecsimple" 3
503 1.1 mrg (and (eq_attr "type" "vecsimple")
504 1.1 mrg (eq_attr "cpu" "power6"))
505 1.1 mrg "FPU_power6")
506 1.1 mrg
507 1.1 mrg (define_bypass 6 "power6-vecsimple" "power6-veccomplex,\
508 1.1 mrg power6-vecperm")
509 1.1 mrg
510 1.1 mrg (define_bypass 5 "power6-vecsimple" "power6-vecfloat")
511 1.1 mrg
512 1.1 mrg (define_bypass 4 "power6-vecsimple" "power6-vecstore" )
513 1.1 mrg
514 1.1 mrg (define_insn_reservation "power6-veccmp" 1
515 1.1 mrg (and (eq_attr "type" "veccmp")
516 1.1 mrg (eq_attr "cpu" "power6"))
517 1.1 mrg "FPU_power6")
518 1.1 mrg
519 1.1 mrg (define_bypass 10 "power6-veccmp" "power6-branch")
520 1.1 mrg
521 1.1 mrg (define_insn_reservation "power6-vecfloat" 7
522 1.1 mrg (and (eq_attr "type" "vecfloat")
523 1.1 mrg (eq_attr "cpu" "power6"))
524 1.1 mrg "FPU_power6")
525 1.1 mrg
526 1.1 mrg (define_bypass 10 "power6-vecfloat" "power6-vecsimple")
527 1.1 mrg
528 1.1 mrg (define_bypass 11 "power6-vecfloat" "power6-veccomplex,\
529 1.1 mrg power6-vecperm")
530 1.1 mrg
531 1.1 mrg (define_bypass 9 "power6-vecfloat" "power6-vecstore" )
532 1.1 mrg
533 1.1 mrg (define_insn_reservation "power6-veccomplex" 7
534 1.1 mrg (and (eq_attr "type" "vecsimple")
535 1.1 mrg (eq_attr "cpu" "power6"))
536 1.1 mrg "FPU_power6")
537 1.1 mrg
538 1.1 mrg (define_bypass 10 "power6-veccomplex" "power6-vecsimple,\
539 1.1 mrg power6-vecfloat" )
540 1.1 mrg
541 1.1 mrg (define_bypass 9 "power6-veccomplex" "power6-vecperm" )
542 1.1 mrg
543 1.1 mrg (define_bypass 8 "power6-veccomplex" "power6-vecstore" )
544 1.1 mrg
545 1.1 mrg (define_insn_reservation "power6-vecperm" 4
546 1.1 mrg (and (eq_attr "type" "vecperm")
547 1.1 mrg (eq_attr "cpu" "power6"))
548 1.1 mrg "FPU_power6")
549 1.1 mrg
550 1.1 mrg (define_bypass 7 "power6-vecperm" "power6-vecsimple,\
551 1.1 mrg power6-vecfloat" )
552 1.1 mrg
553 1.1 mrg (define_bypass 6 "power6-vecperm" "power6-veccomplex" )
554 1.1 mrg
555 1.1 mrg (define_bypass 5 "power6-vecperm" "power6-vecstore" )
556 1.1 mrg
557 1.1 mrg (define_insn_reservation "power6-mftgpr" 8
558 1.1 mrg (and (eq_attr "type" "mftgpr")
559 1.1 mrg (eq_attr "cpu" "power6"))
560 1.1 mrg "X2F_power6")
561 1.1 mrg
562 1.1 mrg (define_insn_reservation "power6-mffgpr" 14
563 1.1 mrg (and (eq_attr "type" "mffgpr")
564 1.1 mrg (eq_attr "cpu" "power6"))
565 1.1 mrg "LX2_power6")
566 1.1 mrg
567 1.1 mrg (define_bypass 4 "power6-mftgpr" "power6-imul,\
568 1.1 mrg power6-lmul,\
569 1.1 mrg power6-imul-cmp,\
570 1.1 mrg power6-lmul-cmp,\
571 1.1 mrg power6-imul3,\
572 1.1 mrg power6-idiv,\
573 1.1 mrg power6-ldiv" )
574