1//=- AArch64SchedA57WriteRes.td - ARM Cortex-A57 Write Res ---*- tablegen -*-=//
2//
3//                     The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// Contains all of the Cortex-A57 specific SchedWriteRes types. The approach
11// below is to define a generic SchedWriteRes for every combination of
12// latency and microOps. The naming conventions is to use a prefix, one field
13// for latency, and one or more microOp count/type designators.
14//   Prefix: A57Write
15//   Latency: #cyc
16//   MicroOp Count/Types: #(B|I|M|L|S|X|W|V)
17//
18// e.g. A57Write_6cyc_1I_6S_4V means the total latency is 6 and there are
19//      11 micro-ops to be issued down one I pipe, six S pipes and four V pipes.
20//
21//===----------------------------------------------------------------------===//
22
23//===----------------------------------------------------------------------===//
24// Define Generic 1 micro-op types
25
26def A57Write_5cyc_1L  : SchedWriteRes<[A57UnitL]> { let Latency = 5;  }
27def A57Write_5cyc_1M  : SchedWriteRes<[A57UnitM]> { let Latency = 5;  }
28def A57Write_5cyc_1V  : SchedWriteRes<[A57UnitV]> { let Latency = 5;  }
29def A57Write_5cyc_1W  : SchedWriteRes<[A57UnitW]> { let Latency = 5;  }
30def A57Write_10cyc_1V : SchedWriteRes<[A57UnitV]> { let Latency = 10; }
31def A57Write_18cyc_1X : SchedWriteRes<[A57UnitX]> { let Latency = 18;
32                                                    let ResourceCycles = [18]; }
33def A57Write_19cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 19;
34                                                    let ResourceCycles = [19]; }
35def A57Write_1cyc_1B  : SchedWriteRes<[A57UnitB]> { let Latency = 1;  }
36def A57Write_1cyc_1I  : SchedWriteRes<[A57UnitI]> { let Latency = 1;  }
37def A57Write_1cyc_1S  : SchedWriteRes<[A57UnitS]> { let Latency = 1;  }
38def A57Write_2cyc_1M  : SchedWriteRes<[A57UnitM]> { let Latency = 2;  }
39def A57Write_32cyc_1X : SchedWriteRes<[A57UnitX]> { let Latency = 32;
40                                                    let ResourceCycles = [32]; }
41def A57Write_35cyc_1M : SchedWriteRes<[A57UnitM]> { let Latency = 35;
42                                                    let ResourceCycles = [35]; }
43def A57Write_3cyc_1M  : SchedWriteRes<[A57UnitM]> { let Latency = 3;  }
44def A57Write_3cyc_1V  : SchedWriteRes<[A57UnitV]> { let Latency = 3;  }
45def A57Write_3cyc_1W  : SchedWriteRes<[A57UnitW]> { let Latency = 3;  }
46def A57Write_3cyc_1X  : SchedWriteRes<[A57UnitX]> { let Latency = 3;  }
47def A57Write_4cyc_1L  : SchedWriteRes<[A57UnitL]> { let Latency = 4;  }
48def A57Write_4cyc_1X  : SchedWriteRes<[A57UnitX]> { let Latency = 4;  }
49def A57Write_9cyc_1V  : SchedWriteRes<[A57UnitV]> { let Latency = 9;  }
50def A57Write_6cyc_1M  : SchedWriteRes<[A57UnitM]> { let Latency = 6;  }
51def A57Write_6cyc_1V  : SchedWriteRes<[A57UnitV]> { let Latency = 6;  }
52
53
54//===----------------------------------------------------------------------===//
55// Define Generic 2 micro-op types
56
57def A57Write_64cyc_2X    : SchedWriteRes<[A57UnitX, A57UnitX]> {
58  let Latency     = 64;
59  let NumMicroOps = 2;
60  let ResourceCycles = [32, 32];
61}
62def A57Write_6cyc_1I_1L  : SchedWriteRes<[A57UnitI,
63                                          A57UnitL]> {
64  let Latency     = 6;
65  let NumMicroOps = 2;
66}
67def A57Write_7cyc_1V_1X  : SchedWriteRes<[A57UnitV,
68                                          A57UnitX]> {
69  let Latency     = 7;
70  let NumMicroOps = 2;
71}
72def A57Write_8cyc_1L_1V  : SchedWriteRes<[A57UnitL,
73                                          A57UnitV]> {
74  let Latency     = 8;
75  let NumMicroOps = 2;
76}
77def A57Write_9cyc_2V     : SchedWriteRes<[A57UnitV, A57UnitV]> {
78  let Latency     = 9;
79  let NumMicroOps = 2;
80}
81def A57Write_8cyc_2X     : SchedWriteRes<[A57UnitX, A57UnitX]> {
82  let Latency     = 8;
83  let NumMicroOps = 2;
84}
85def A57Write_6cyc_2L     : SchedWriteRes<[A57UnitL, A57UnitL]> {
86  let Latency     = 6;
87  let NumMicroOps = 2;
88}
89def A57Write_6cyc_2V     : SchedWriteRes<[A57UnitV, A57UnitV]> {
90  let Latency     = 6;
91  let NumMicroOps = 2;
92}
93def A57Write_6cyc_2W     : SchedWriteRes<[A57UnitW, A57UnitW]> {
94  let Latency     = 6;
95  let NumMicroOps = 2;
96}
97def A57Write_5cyc_1I_1L  : SchedWriteRes<[A57UnitI,
98                                          A57UnitL]> {
99  let Latency     = 5;
100  let NumMicroOps = 2;
101}
102def A57Write_5cyc_2V     : SchedWriteRes<[A57UnitV, A57UnitV]> {
103  let Latency     = 5;
104  let NumMicroOps = 2;
105}
106def A57Write_5cyc_2X     : SchedWriteRes<[A57UnitX, A57UnitX]> {
107  let Latency     = 5;
108  let NumMicroOps = 2;
109}
110def A57Write_10cyc_1L_1V : SchedWriteRes<[A57UnitL,
111                                          A57UnitV]> {
112  let Latency     = 10;
113  let NumMicroOps = 2;
114}
115def A57Write_10cyc_2V    : SchedWriteRes<[A57UnitV, A57UnitV]> {
116  let Latency     = 10;
117  let NumMicroOps = 2;
118}
119def A57Write_1cyc_1B_1I  : SchedWriteRes<[A57UnitB,
120                                          A57UnitI]> {
121  let Latency     = 1;
122  let NumMicroOps = 2;
123}
124def A57Write_1cyc_1I_1S  : SchedWriteRes<[A57UnitI,
125                                          A57UnitS]> {
126  let Latency     = 1;
127  let NumMicroOps = 2;
128}
129def A57Write_2cyc_1B_1I  : SchedWriteRes<[A57UnitB,
130                                          A57UnitI]> {
131  let Latency     = 2;
132  let NumMicroOps = 2;
133}
134def A57Write_2cyc_2S     : SchedWriteRes<[A57UnitS, A57UnitS]> {
135  let Latency     = 2;
136  let NumMicroOps = 2;
137}
138def A57Write_2cyc_2V     : SchedWriteRes<[A57UnitV, A57UnitV]> {
139  let Latency     = 2;
140  let NumMicroOps = 2;
141}
142def A57Write_36cyc_2X    : SchedWriteRes<[A57UnitX, A57UnitX]> {
143  let Latency     = 36;
144  let NumMicroOps = 2;
145  let ResourceCycles = [18, 18];
146}
147def A57Write_3cyc_1I_1M  : SchedWriteRes<[A57UnitI,
148                                          A57UnitM]> {
149  let Latency     = 3;
150  let NumMicroOps = 2;
151}
152def A57Write_3cyc_1I_1S  : SchedWriteRes<[A57UnitI,
153                                          A57UnitS]> {
154  let Latency     = 3;
155  let NumMicroOps = 2;
156}
157def A57Write_3cyc_1S_1V  : SchedWriteRes<[A57UnitS,
158                                          A57UnitV]> {
159  let Latency     = 3;
160  let NumMicroOps = 2;
161}
162def A57Write_3cyc_2V     : SchedWriteRes<[A57UnitV, A57UnitV]> {
163  let Latency     = 3;
164  let NumMicroOps = 2;
165}
166def A57Write_4cyc_1I_1L  : SchedWriteRes<[A57UnitI,
167                                          A57UnitL]> {
168  let Latency     = 4;
169  let NumMicroOps = 2;
170}
171def A57Write_4cyc_2X     : SchedWriteRes<[A57UnitX, A57UnitX]> {
172  let Latency     = 4;
173  let NumMicroOps = 2;
174}
175
176
177//===----------------------------------------------------------------------===//
178// Define Generic 3 micro-op types
179
180def A57Write_10cyc_3V       : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> {
181  let Latency     = 10;
182  let NumMicroOps = 3;
183}
184def A57Write_2cyc_1I_2S     : SchedWriteRes<[A57UnitI,
185                                             A57UnitS, A57UnitS]> {
186  let Latency     = 2;
187  let NumMicroOps = 3;
188}
189def A57Write_3cyc_1I_1S_1V  : SchedWriteRes<[A57UnitI,
190                                             A57UnitS,
191                                             A57UnitV]> {
192  let Latency     = 3;
193  let NumMicroOps = 3;
194}
195def A57Write_3cyc_1M_2S     : SchedWriteRes<[A57UnitM,
196                                             A57UnitS, A57UnitS]> {
197  let Latency     = 3;
198  let NumMicroOps = 3;
199}
200def A57Write_3cyc_3S        : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS]> {
201  let Latency     = 3;
202  let NumMicroOps = 3;
203}
204def A57Write_3cyc_2S_1V     : SchedWriteRes<[A57UnitS, A57UnitS,
205                                             A57UnitV]> {
206  let Latency     = 3;
207  let NumMicroOps = 3;
208}
209def A57Write_5cyc_1I_2L     : SchedWriteRes<[A57UnitI,
210                                             A57UnitL, A57UnitL]> {
211  let Latency     = 5;
212  let NumMicroOps = 3;
213}
214def A57Write_6cyc_1I_2L     : SchedWriteRes<[A57UnitI,
215                                             A57UnitL, A57UnitL]> {
216  let Latency     = 6;
217  let NumMicroOps = 3;
218}
219def A57Write_6cyc_3V        : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> {
220  let Latency     = 6;
221  let NumMicroOps = 3;
222}
223def A57Write_7cyc_3L        : SchedWriteRes<[A57UnitL, A57UnitL, A57UnitL]> {
224  let Latency     = 7;
225  let NumMicroOps = 3;
226}
227def A57Write_8cyc_1I_1L_1V  : SchedWriteRes<[A57UnitI,
228                                             A57UnitL,
229                                             A57UnitV]> {
230  let Latency     = 8;
231  let NumMicroOps = 3;
232}
233def A57Write_8cyc_1L_2V     : SchedWriteRes<[A57UnitL,
234                                             A57UnitV, A57UnitV]> {
235  let Latency     = 8;
236  let NumMicroOps = 3;
237}
238def A57Write_8cyc_3V        : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> {
239  let Latency     = 8;
240  let NumMicroOps = 3;
241}
242def A57Write_9cyc_3V        : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV]> {
243  let Latency     = 9;
244  let NumMicroOps = 3;
245}
246
247
248//===----------------------------------------------------------------------===//
249// Define Generic 4 micro-op types
250
251def A57Write_2cyc_2I_2S    : SchedWriteRes<[A57UnitI, A57UnitI,
252                                            A57UnitS, A57UnitS]> {
253  let Latency     = 2;
254  let NumMicroOps = 4;
255}
256def A57Write_3cyc_2I_2S    : SchedWriteRes<[A57UnitI, A57UnitI,
257                                            A57UnitS, A57UnitS]> {
258  let Latency     = 3;
259  let NumMicroOps = 4;
260}
261def A57Write_3cyc_1I_3S    : SchedWriteRes<[A57UnitI,
262                                            A57UnitS, A57UnitS, A57UnitS]> {
263  let Latency     = 3;
264  let NumMicroOps = 4;
265}
266def A57Write_3cyc_1I_2S_1V : SchedWriteRes<[A57UnitI,
267                                            A57UnitS, A57UnitS,
268                                            A57UnitV]> {
269  let Latency     = 3;
270  let NumMicroOps = 4;
271}
272def A57Write_4cyc_4S       : SchedWriteRes<[A57UnitS, A57UnitS,
273                                            A57UnitS, A57UnitS]> {
274  let Latency     = 4;
275  let NumMicroOps = 4;
276}
277def A57Write_7cyc_1I_3L    : SchedWriteRes<[A57UnitI,
278                                            A57UnitL, A57UnitL, A57UnitL]> {
279  let Latency     = 7;
280  let NumMicroOps = 4;
281}
282def A57Write_5cyc_2I_2L    : SchedWriteRes<[A57UnitI, A57UnitI,
283                                            A57UnitL, A57UnitL]> {
284  let Latency     = 5;
285  let NumMicroOps = 4;
286}
287def A57Write_8cyc_1I_1L_2V : SchedWriteRes<[A57UnitI,
288                                            A57UnitL,
289                                            A57UnitV, A57UnitV]> {
290  let Latency     = 8;
291  let NumMicroOps = 4;
292}
293def A57Write_8cyc_4L       : SchedWriteRes<[A57UnitL, A57UnitL,
294                                            A57UnitL, A57UnitL]> {
295  let Latency     = 8;
296  let NumMicroOps = 4;
297}
298def A57Write_9cyc_2L_2V    : SchedWriteRes<[A57UnitL, A57UnitL,
299                                            A57UnitV, A57UnitV]> {
300  let Latency     = 9;
301  let NumMicroOps = 4;
302}
303def A57Write_9cyc_1L_3V    : SchedWriteRes<[A57UnitL,
304                                            A57UnitV, A57UnitV, A57UnitV]> {
305  let Latency     = 9;
306  let NumMicroOps = 4;
307}
308def A57Write_12cyc_4V      : SchedWriteRes<[A57UnitV, A57UnitV,
309                                            A57UnitV, A57UnitV]> {
310  let Latency     = 12;
311  let NumMicroOps = 4;
312}
313
314
315//===----------------------------------------------------------------------===//
316// Define Generic 5 micro-op types
317
318def A57Write_3cyc_3S_2V    : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS,
319                                            A57UnitV, A57UnitV]> {
320  let Latency     = 3;
321  let NumMicroOps = 5;
322}
323def A57Write_8cyc_1I_4L    : SchedWriteRes<[A57UnitI,
324                                            A57UnitL, A57UnitL,
325                                            A57UnitL, A57UnitL]> {
326  let Latency     = 8;
327  let NumMicroOps = 5;
328}
329def A57Write_4cyc_1I_4S    : SchedWriteRes<[A57UnitI,
330                                            A57UnitS, A57UnitS,
331                                            A57UnitS, A57UnitS]> {
332  let Latency     = 4;
333  let NumMicroOps = 5;
334}
335def A57Write_9cyc_1I_2L_2V : SchedWriteRes<[A57UnitI,
336                                            A57UnitL, A57UnitL,
337                                            A57UnitV, A57UnitV]> {
338  let Latency     = 9;
339  let NumMicroOps = 5;
340}
341def A57Write_9cyc_1I_1L_3V : SchedWriteRes<[A57UnitI,
342                                            A57UnitL,
343                                            A57UnitV, A57UnitV, A57UnitV]> {
344  let Latency     = 9;
345  let NumMicroOps = 5;
346}
347def A57Write_9cyc_2L_3V    : SchedWriteRes<[A57UnitL, A57UnitL,
348                                            A57UnitV, A57UnitV, A57UnitV]> {
349  let Latency     = 9;
350  let NumMicroOps = 5;
351}
352def A57Write_9cyc_5V       : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV,
353                                            A57UnitV, A57UnitV]> {
354  let Latency     = 9;
355  let NumMicroOps = 5;
356}
357
358
359//===----------------------------------------------------------------------===//
360// Define Generic 6 micro-op types
361
362def A57Write_3cyc_1I_3S_2V : SchedWriteRes<[A57UnitI,
363                                            A57UnitS, A57UnitS, A57UnitS,
364                                            A57UnitV, A57UnitV]> {
365  let Latency     = 3;
366  let NumMicroOps = 6;
367}
368def A57Write_4cyc_2I_4S    : SchedWriteRes<[A57UnitI, A57UnitI,
369                                            A57UnitS, A57UnitS,
370                                            A57UnitS, A57UnitS]> {
371  let Latency     = 4;
372  let NumMicroOps = 6;
373}
374def A57Write_4cyc_4S_2V    : SchedWriteRes<[A57UnitS, A57UnitS,
375                                            A57UnitS, A57UnitS,
376                                            A57UnitV, A57UnitV]> {
377  let Latency     = 4;
378  let NumMicroOps = 6;
379}
380def A57Write_6cyc_6S       : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS,
381                                            A57UnitS, A57UnitS, A57UnitS]> {
382  let Latency     = 6;
383  let NumMicroOps = 6;
384}
385def A57Write_9cyc_1I_2L_3V : SchedWriteRes<[A57UnitI,
386                                            A57UnitL, A57UnitL,
387                                            A57UnitV, A57UnitV, A57UnitV]> {
388  let Latency     = 9;
389  let NumMicroOps = 6;
390}
391def A57Write_9cyc_1I_1L_4V : SchedWriteRes<[A57UnitI,
392                                            A57UnitL,
393                                            A57UnitV, A57UnitV,
394                                            A57UnitV, A57UnitV]> {
395  let Latency     = 9;
396  let NumMicroOps = 6;
397}
398def A57Write_9cyc_2L_4V    : SchedWriteRes<[A57UnitL, A57UnitL,
399                                            A57UnitV, A57UnitV,
400                                            A57UnitV, A57UnitV]> {
401  let Latency     = 9;
402  let NumMicroOps = 6;
403}
404
405
406//===----------------------------------------------------------------------===//
407// Define Generic 7 micro-op types
408
409def A57Write_10cyc_3L_4V : SchedWriteRes<[A57UnitL, A57UnitL, A57UnitL,
410                                          A57UnitV, A57UnitV,
411                                          A57UnitV, A57UnitV]> {
412  let Latency     = 10;
413  let NumMicroOps = 7;
414}
415def A57Write_4cyc_1I_4S_2V  : SchedWriteRes<[A57UnitI,
416                                             A57UnitS, A57UnitS,
417                                             A57UnitS, A57UnitS,
418                                             A57UnitV, A57UnitV]> {
419  let Latency     = 4;
420  let NumMicroOps = 7;
421}
422def A57Write_6cyc_1I_6S     : SchedWriteRes<[A57UnitI,
423                                          A57UnitS, A57UnitS, A57UnitS,
424                                          A57UnitS, A57UnitS, A57UnitS]> {
425  let Latency     = 6;
426  let NumMicroOps = 7;
427}
428def A57Write_9cyc_1I_2L_4V  : SchedWriteRes<[A57UnitI,
429                                             A57UnitL, A57UnitL,
430                                             A57UnitV, A57UnitV,
431                                             A57UnitV, A57UnitV]> {
432  let Latency     = 9;
433  let NumMicroOps = 7;
434}
435def A57Write_12cyc_7V       : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV,
436                                             A57UnitV, A57UnitV,
437                                             A57UnitV, A57UnitV]> {
438  let Latency     = 12;
439  let NumMicroOps = 7;
440}
441
442
443//===----------------------------------------------------------------------===//
444// Define Generic 8 micro-op types
445
446def A57Write_10cyc_1I_3L_4V : SchedWriteRes<[A57UnitI,
447                                             A57UnitL, A57UnitL, A57UnitL,
448                                             A57UnitV, A57UnitV,
449                                             A57UnitV, A57UnitV]> {
450  let Latency     = 10;
451  let NumMicroOps = 8;
452}
453def A57Write_11cyc_4L_4V : SchedWriteRes<[A57UnitL, A57UnitL,
454                                          A57UnitL, A57UnitL,
455                                          A57UnitV, A57UnitV,
456                                          A57UnitV, A57UnitV]> {
457  let Latency     = 11;
458  let NumMicroOps = 8;
459}
460def A57Write_8cyc_8S  : SchedWriteRes<[A57UnitS, A57UnitS,
461                                       A57UnitS, A57UnitS,
462                                       A57UnitS, A57UnitS,
463                                       A57UnitS, A57UnitS]> {
464  let Latency     = 8;
465  let NumMicroOps = 8;
466}
467
468
469//===----------------------------------------------------------------------===//
470// Define Generic 9 micro-op types
471
472def A57Write_8cyc_1I_8S     : SchedWriteRes<[A57UnitI,
473                                            A57UnitS, A57UnitS,
474                                            A57UnitS, A57UnitS,
475                                            A57UnitS, A57UnitS,
476                                            A57UnitS, A57UnitS]> {
477  let Latency     = 8;
478  let NumMicroOps = 9;
479}
480def A57Write_11cyc_1I_4L_4V : SchedWriteRes<[A57UnitI,
481                                             A57UnitL, A57UnitL,
482                                             A57UnitL, A57UnitL,
483                                             A57UnitV, A57UnitV,
484                                             A57UnitV, A57UnitV]> {
485  let Latency     = 11;
486  let NumMicroOps = 9;
487}
488def A57Write_15cyc_9V       : SchedWriteRes<[A57UnitV, A57UnitV, A57UnitV,
489                                             A57UnitV, A57UnitV, A57UnitV,
490                                             A57UnitV, A57UnitV, A57UnitV]> {
491  let Latency     = 15;
492  let NumMicroOps = 9;
493}
494
495
496//===----------------------------------------------------------------------===//
497// Define Generic 10 micro-op types
498
499def A57Write_6cyc_6S_4V : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS,
500                                         A57UnitS, A57UnitS, A57UnitS,
501                                         A57UnitV, A57UnitV,
502                                         A57UnitV, A57UnitV]> {
503  let Latency     = 6;
504  let NumMicroOps = 10;
505}
506
507
508//===----------------------------------------------------------------------===//
509// Define Generic 11 micro-op types
510
511def A57Write_6cyc_1I_6S_4V : SchedWriteRes<[A57UnitI,
512                                            A57UnitS, A57UnitS, A57UnitS,
513                                            A57UnitS, A57UnitS, A57UnitS,
514                                            A57UnitV, A57UnitV,
515                                            A57UnitV, A57UnitV]> {
516  let Latency     = 6;
517  let NumMicroOps = 11;
518}
519
520
521//===----------------------------------------------------------------------===//
522// Define Generic 12 micro-op types
523
524def A57Write_8cyc_8S_4V : SchedWriteRes<[A57UnitS, A57UnitS, A57UnitS, A57UnitS,
525                                         A57UnitS, A57UnitS, A57UnitS, A57UnitS,
526                                         A57UnitV, A57UnitV,
527                                         A57UnitV, A57UnitV]> {
528  let Latency     = 8;
529  let NumMicroOps = 12;
530}
531
532//===----------------------------------------------------------------------===//
533// Define Generic 13 micro-op types
534
535def A57Write_8cyc_1I_8S_4V : SchedWriteRes<[A57UnitI,
536                                            A57UnitS, A57UnitS, A57UnitS,
537                                            A57UnitS, A57UnitS, A57UnitS,
538                                            A57UnitS, A57UnitS,
539                                            A57UnitV, A57UnitV,
540                                            A57UnitV, A57UnitV]> {
541  let Latency     = 8;
542  let NumMicroOps = 13;
543}
544
545