power6.md revision 1.3 1 1.1 mrg ;; Scheduling description for IBM POWER6 processor.
2 1.3 mrg ;; Copyright (C) 2006-2013 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.3 mrg (define_insn_reservation "power6-popcnt" 1
220 1.3 mrg (and (eq_attr "type" "popcnt")
221 1.3 mrg (eq_attr "cpu" "power6"))
222 1.3 mrg "FXU_power6")
223 1.3 mrg
224 1.1 mrg (define_insn_reservation "power6-insert" 1
225 1.1 mrg (and (eq_attr "type" "insert_word")
226 1.1 mrg (eq_attr "cpu" "power6"))
227 1.1 mrg "FX2_power6")
228 1.1 mrg
229 1.1 mrg (define_insn_reservation "power6-insert-dword" 1
230 1.1 mrg (and (eq_attr "type" "insert_dword")
231 1.1 mrg (eq_attr "cpu" "power6"))
232 1.1 mrg "FX2_power6")
233 1.1 mrg
234 1.1 mrg ; define the bypass for the case where the value written
235 1.1 mrg ; by a fixed point op is used as the source value on a
236 1.1 mrg ; store.
237 1.1 mrg (define_bypass 1 "power6-integer,\
238 1.1 mrg power6-exts,\
239 1.1 mrg power6-shift,\
240 1.1 mrg power6-insert,\
241 1.1 mrg power6-insert-dword"
242 1.1 mrg "power6-store,\
243 1.1 mrg power6-store-update,\
244 1.1 mrg power6-store-update-indexed,\
245 1.1 mrg power6-fpstore,\
246 1.1 mrg power6-fpstore-update"
247 1.1 mrg "store_data_bypass_p")
248 1.1 mrg
249 1.1 mrg (define_insn_reservation "power6-cntlz" 2
250 1.1 mrg (and (eq_attr "type" "cntlz")
251 1.1 mrg (eq_attr "cpu" "power6"))
252 1.1 mrg "FXU_power6")
253 1.1 mrg
254 1.1 mrg (define_bypass 1 "power6-cntlz"
255 1.1 mrg "power6-store,\
256 1.1 mrg power6-store-update,\
257 1.1 mrg power6-store-update-indexed,\
258 1.1 mrg power6-fpstore,\
259 1.1 mrg power6-fpstore-update"
260 1.1 mrg "store_data_bypass_p")
261 1.1 mrg
262 1.1 mrg (define_insn_reservation "power6-var-rotate" 4
263 1.1 mrg (and (eq_attr "type" "var_shift_rotate")
264 1.1 mrg (eq_attr "cpu" "power6"))
265 1.1 mrg "FXU_power6")
266 1.1 mrg
267 1.1 mrg (define_insn_reservation "power6-trap" 1 ; N/A
268 1.1 mrg (and (eq_attr "type" "trap")
269 1.1 mrg (eq_attr "cpu" "power6"))
270 1.1 mrg "BRX_power6")
271 1.1 mrg
272 1.1 mrg (define_insn_reservation "power6-two" 1
273 1.1 mrg (and (eq_attr "type" "two")
274 1.1 mrg (eq_attr "cpu" "power6"))
275 1.1 mrg "(iu1_power6,iu1_power6)\
276 1.1 mrg |(iu1_power6+iu2_power6,nothing)\
277 1.1 mrg |(iu1_power6,iu2_power6)\
278 1.1 mrg |(iu2_power6,iu1_power6)\
279 1.1 mrg |(iu2_power6,iu2_power6)")
280 1.1 mrg
281 1.1 mrg (define_insn_reservation "power6-three" 1
282 1.1 mrg (and (eq_attr "type" "three")
283 1.1 mrg (eq_attr "cpu" "power6"))
284 1.1 mrg "(iu1_power6,iu1_power6,iu1_power6)\
285 1.1 mrg |(iu1_power6,iu1_power6,iu2_power6)\
286 1.1 mrg |(iu1_power6,iu2_power6,iu1_power6)\
287 1.1 mrg |(iu1_power6,iu2_power6,iu2_power6)\
288 1.1 mrg |(iu2_power6,iu1_power6,iu1_power6)\
289 1.1 mrg |(iu2_power6,iu1_power6,iu2_power6)\
290 1.1 mrg |(iu2_power6,iu2_power6,iu1_power6)\
291 1.1 mrg |(iu2_power6,iu2_power6,iu2_power6)\
292 1.1 mrg |(iu1_power6+iu2_power6,iu1_power6)\
293 1.1 mrg |(iu1_power6+iu2_power6,iu2_power6)\
294 1.1 mrg |(iu1_power6,iu1_power6+iu2_power6)\
295 1.1 mrg |(iu2_power6,iu1_power6+iu2_power6)")
296 1.1 mrg
297 1.1 mrg (define_insn_reservation "power6-cmp" 1
298 1.1 mrg (and (eq_attr "type" "cmp")
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-compare" 1
303 1.1 mrg (and (eq_attr "type" "compare")
304 1.1 mrg (eq_attr "cpu" "power6"))
305 1.1 mrg "FXU_power6")
306 1.1 mrg
307 1.1 mrg (define_insn_reservation "power6-fast-compare" 1
308 1.1 mrg (and (eq_attr "type" "fast_compare")
309 1.1 mrg (eq_attr "cpu" "power6"))
310 1.1 mrg "FXU_power6")
311 1.1 mrg
312 1.1 mrg ; define the bypass for the case where the value written
313 1.1 mrg ; by a fixed point rec form op is used as the source value
314 1.1 mrg ; on a store.
315 1.1 mrg (define_bypass 1 "power6-compare,\
316 1.1 mrg power6-fast-compare"
317 1.1 mrg "power6-store,\
318 1.1 mrg power6-store-update,\
319 1.1 mrg power6-store-update-indexed,\
320 1.1 mrg power6-fpstore,\
321 1.1 mrg power6-fpstore-update"
322 1.1 mrg "store_data_bypass_p")
323 1.1 mrg
324 1.1 mrg (define_insn_reservation "power6-delayed-compare" 2 ; N/A
325 1.1 mrg (and (eq_attr "type" "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-var-delayed-compare" 4
330 1.1 mrg (and (eq_attr "type" "var_delayed_compare")
331 1.1 mrg (eq_attr "cpu" "power6"))
332 1.1 mrg "FXU_power6")
333 1.1 mrg
334 1.1 mrg (define_insn_reservation "power6-lmul-cmp" 16
335 1.1 mrg (and (eq_attr "type" "lmul_compare")
336 1.1 mrg (eq_attr "cpu" "power6"))
337 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
338 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
339 1.1 mrg
340 1.1 mrg (define_insn_reservation "power6-imul-cmp" 16
341 1.1 mrg (and (eq_attr "type" "imul_compare")
342 1.1 mrg (eq_attr "cpu" "power6"))
343 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
344 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
345 1.1 mrg
346 1.1 mrg (define_insn_reservation "power6-lmul" 16
347 1.1 mrg (and (eq_attr "type" "lmul")
348 1.1 mrg (eq_attr "cpu" "power6"))
349 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
350 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
351 1.1 mrg
352 1.1 mrg (define_insn_reservation "power6-imul" 16
353 1.1 mrg (and (eq_attr "type" "imul")
354 1.1 mrg (eq_attr "cpu" "power6"))
355 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
356 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
357 1.1 mrg
358 1.1 mrg (define_insn_reservation "power6-imul3" 16
359 1.1 mrg (and (eq_attr "type" "imul2,imul3")
360 1.1 mrg (eq_attr "cpu" "power6"))
361 1.1 mrg "(iu1_power6*16+iu2_power6*16+fpu1_power6*16)\
362 1.1 mrg |(iu1_power6*16+iu2_power6*16+fpu2_power6*16)");
363 1.1 mrg
364 1.1 mrg (define_bypass 9 "power6-imul,\
365 1.1 mrg power6-lmul,\
366 1.1 mrg power6-imul-cmp,\
367 1.1 mrg power6-lmul-cmp,\
368 1.1 mrg power6-imul3"
369 1.1 mrg "power6-store,\
370 1.1 mrg power6-store-update,\
371 1.1 mrg power6-store-update-indexed,\
372 1.1 mrg power6-fpstore,\
373 1.1 mrg power6-fpstore-update"
374 1.1 mrg "store_data_bypass_p")
375 1.1 mrg
376 1.1 mrg (define_insn_reservation "power6-idiv" 44
377 1.1 mrg (and (eq_attr "type" "idiv")
378 1.1 mrg (eq_attr "cpu" "power6"))
379 1.1 mrg "(iu1_power6*44+iu2_power6*44+fpu1_power6*44)\
380 1.1 mrg |(iu1_power6*44+iu2_power6*44+fpu2_power6*44)");
381 1.1 mrg
382 1.1 mrg ; The latency for this bypass is yet to be defined
383 1.1 mrg ;(define_bypass ? "power6-idiv"
384 1.1 mrg ; "power6-store,\
385 1.1 mrg ; power6-store-update,\
386 1.1 mrg ; power6-store-update-indexed,\
387 1.1 mrg ; power6-fpstore,\
388 1.1 mrg ; power6-fpstore-update"
389 1.1 mrg ; "store_data_bypass_p")
390 1.1 mrg
391 1.1 mrg (define_insn_reservation "power6-ldiv" 56
392 1.1 mrg (and (eq_attr "type" "ldiv")
393 1.1 mrg (eq_attr "cpu" "power6"))
394 1.1 mrg "(iu1_power6*56+iu2_power6*56+fpu1_power6*56)\
395 1.1 mrg |(iu1_power6*56+iu2_power6*56+fpu2_power6*56)");
396 1.1 mrg
397 1.1 mrg ; The latency for this bypass is yet to be defined
398 1.1 mrg ;(define_bypass ? "power6-ldiv"
399 1.1 mrg ; "power6-store,\
400 1.1 mrg ; power6-store-update,\
401 1.1 mrg ; power6-store-update-indexed,\
402 1.1 mrg ; power6-fpstore,\
403 1.1 mrg ; power6-fpstore-update"
404 1.1 mrg ; "store_data_bypass_p")
405 1.1 mrg
406 1.1 mrg (define_insn_reservation "power6-mtjmpr" 2
407 1.1 mrg (and (eq_attr "type" "mtjmpr,mfjmpr")
408 1.1 mrg (eq_attr "cpu" "power6"))
409 1.1 mrg "BX2_power6")
410 1.1 mrg
411 1.1 mrg (define_bypass 5 "power6-mtjmpr" "power6-branch")
412 1.1 mrg
413 1.1 mrg (define_insn_reservation "power6-branch" 2
414 1.1 mrg (and (eq_attr "type" "jmpreg,branch")
415 1.1 mrg (eq_attr "cpu" "power6"))
416 1.1 mrg "BRU_power6")
417 1.1 mrg
418 1.1 mrg (define_bypass 5 "power6-branch" "power6-mtjmpr")
419 1.1 mrg
420 1.1 mrg (define_insn_reservation "power6-crlogical" 3
421 1.1 mrg (and (eq_attr "type" "cr_logical")
422 1.1 mrg (eq_attr "cpu" "power6"))
423 1.1 mrg "BRU_power6")
424 1.1 mrg
425 1.1 mrg (define_bypass 3 "power6-crlogical" "power6-branch")
426 1.1 mrg
427 1.1 mrg (define_insn_reservation "power6-delayedcr" 3
428 1.1 mrg (and (eq_attr "type" "delayed_cr")
429 1.1 mrg (eq_attr "cpu" "power6"))
430 1.1 mrg "BRU_power6")
431 1.1 mrg
432 1.1 mrg (define_insn_reservation "power6-mfcr" 6 ; N/A
433 1.1 mrg (and (eq_attr "type" "mfcr")
434 1.1 mrg (eq_attr "cpu" "power6"))
435 1.1 mrg "BX2_power6")
436 1.1 mrg
437 1.1 mrg ; mfcrf (1 field)
438 1.1 mrg (define_insn_reservation "power6-mfcrf" 3 ; N/A
439 1.1 mrg (and (eq_attr "type" "mfcrf")
440 1.1 mrg (eq_attr "cpu" "power6"))
441 1.1 mrg "BX2_power6") ;
442 1.1 mrg
443 1.1 mrg ; mtcrf (1 field)
444 1.1 mrg (define_insn_reservation "power6-mtcr" 4 ; N/A
445 1.1 mrg (and (eq_attr "type" "mtcr")
446 1.1 mrg (eq_attr "cpu" "power6"))
447 1.1 mrg "BX2_power6")
448 1.1 mrg
449 1.1 mrg (define_bypass 9 "power6-mtcr" "power6-branch")
450 1.1 mrg
451 1.1 mrg (define_insn_reservation "power6-fp" 6
452 1.1 mrg (and (eq_attr "type" "fp,dmul")
453 1.1 mrg (eq_attr "cpu" "power6"))
454 1.1 mrg "FPU_power6")
455 1.1 mrg
456 1.1 mrg ; Any fp instruction that updates a CR has a latency
457 1.1 mrg ; of 6 to a dependent branch
458 1.1 mrg (define_bypass 6 "power6-fp" "power6-branch")
459 1.1 mrg
460 1.1 mrg (define_bypass 1 "power6-fp"
461 1.1 mrg "power6-fpstore,power6-fpstore-update"
462 1.1 mrg "store_data_bypass_p")
463 1.1 mrg
464 1.1 mrg (define_insn_reservation "power6-fpcompare" 8
465 1.1 mrg (and (eq_attr "type" "fpcompare")
466 1.1 mrg (eq_attr "cpu" "power6"))
467 1.1 mrg "FPU_power6")
468 1.1 mrg
469 1.1 mrg (define_bypass 12 "power6-fpcompare"
470 1.1 mrg "power6-branch,power6-crlogical")
471 1.1 mrg
472 1.1 mrg (define_insn_reservation "power6-sdiv" 26
473 1.1 mrg (and (eq_attr "type" "sdiv")
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-ddiv" 32
478 1.1 mrg (and (eq_attr "type" "ddiv")
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-sqrt" 30
483 1.1 mrg (and (eq_attr "type" "ssqrt")
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-dsqrt" 42
488 1.1 mrg (and (eq_attr "type" "dsqrt")
489 1.1 mrg (eq_attr "cpu" "power6"))
490 1.1 mrg "FPU_power6")
491 1.1 mrg
492 1.1 mrg (define_insn_reservation "power6-isync" 2 ; N/A
493 1.1 mrg (and (eq_attr "type" "isync")
494 1.1 mrg (eq_attr "cpu" "power6"))
495 1.1 mrg "FXU_power6")
496 1.1 mrg
497 1.1 mrg (define_insn_reservation "power6-vecload" 1
498 1.1 mrg (and (eq_attr "type" "vecload")
499 1.1 mrg (eq_attr "cpu" "power6"))
500 1.1 mrg "LSU_power6")
501 1.1 mrg
502 1.1 mrg (define_insn_reservation "power6-vecstore" 1
503 1.1 mrg (and (eq_attr "type" "vecstore")
504 1.1 mrg (eq_attr "cpu" "power6"))
505 1.1 mrg "LSF_power6")
506 1.1 mrg
507 1.1 mrg (define_insn_reservation "power6-vecsimple" 3
508 1.1 mrg (and (eq_attr "type" "vecsimple")
509 1.1 mrg (eq_attr "cpu" "power6"))
510 1.1 mrg "FPU_power6")
511 1.1 mrg
512 1.1 mrg (define_bypass 6 "power6-vecsimple" "power6-veccomplex,\
513 1.1 mrg power6-vecperm")
514 1.1 mrg
515 1.1 mrg (define_bypass 5 "power6-vecsimple" "power6-vecfloat")
516 1.1 mrg
517 1.1 mrg (define_bypass 4 "power6-vecsimple" "power6-vecstore" )
518 1.1 mrg
519 1.1 mrg (define_insn_reservation "power6-veccmp" 1
520 1.1 mrg (and (eq_attr "type" "veccmp")
521 1.1 mrg (eq_attr "cpu" "power6"))
522 1.1 mrg "FPU_power6")
523 1.1 mrg
524 1.1 mrg (define_bypass 10 "power6-veccmp" "power6-branch")
525 1.1 mrg
526 1.1 mrg (define_insn_reservation "power6-vecfloat" 7
527 1.1 mrg (and (eq_attr "type" "vecfloat")
528 1.1 mrg (eq_attr "cpu" "power6"))
529 1.1 mrg "FPU_power6")
530 1.1 mrg
531 1.1 mrg (define_bypass 10 "power6-vecfloat" "power6-vecsimple")
532 1.1 mrg
533 1.1 mrg (define_bypass 11 "power6-vecfloat" "power6-veccomplex,\
534 1.1 mrg power6-vecperm")
535 1.1 mrg
536 1.1 mrg (define_bypass 9 "power6-vecfloat" "power6-vecstore" )
537 1.1 mrg
538 1.1 mrg (define_insn_reservation "power6-veccomplex" 7
539 1.1 mrg (and (eq_attr "type" "vecsimple")
540 1.1 mrg (eq_attr "cpu" "power6"))
541 1.1 mrg "FPU_power6")
542 1.1 mrg
543 1.1 mrg (define_bypass 10 "power6-veccomplex" "power6-vecsimple,\
544 1.1 mrg power6-vecfloat" )
545 1.1 mrg
546 1.1 mrg (define_bypass 9 "power6-veccomplex" "power6-vecperm" )
547 1.1 mrg
548 1.1 mrg (define_bypass 8 "power6-veccomplex" "power6-vecstore" )
549 1.1 mrg
550 1.1 mrg (define_insn_reservation "power6-vecperm" 4
551 1.1 mrg (and (eq_attr "type" "vecperm")
552 1.1 mrg (eq_attr "cpu" "power6"))
553 1.1 mrg "FPU_power6")
554 1.1 mrg
555 1.1 mrg (define_bypass 7 "power6-vecperm" "power6-vecsimple,\
556 1.1 mrg power6-vecfloat" )
557 1.1 mrg
558 1.1 mrg (define_bypass 6 "power6-vecperm" "power6-veccomplex" )
559 1.1 mrg
560 1.1 mrg (define_bypass 5 "power6-vecperm" "power6-vecstore" )
561 1.1 mrg
562 1.1 mrg (define_insn_reservation "power6-mftgpr" 8
563 1.1 mrg (and (eq_attr "type" "mftgpr")
564 1.1 mrg (eq_attr "cpu" "power6"))
565 1.1 mrg "X2F_power6")
566 1.1 mrg
567 1.1 mrg (define_insn_reservation "power6-mffgpr" 14
568 1.1 mrg (and (eq_attr "type" "mffgpr")
569 1.1 mrg (eq_attr "cpu" "power6"))
570 1.1 mrg "LX2_power6")
571 1.1 mrg
572 1.1 mrg (define_bypass 4 "power6-mftgpr" "power6-imul,\
573 1.1 mrg power6-lmul,\
574 1.1 mrg power6-imul-cmp,\
575 1.1 mrg power6-lmul-cmp,\
576 1.1 mrg power6-imul3,\
577 1.1 mrg power6-idiv,\
578 1.1 mrg power6-ldiv" )
579