1 (define_automaton "sifive_7")
3 ;; Sifive 7 Series Base Core
4 ;; This has two pipelines, A (Address) and B (Branch).
5 ;; Loads, stores, and FP <-> integer moves use the A-pipe.
6 ;; Branches, MUL/DIV, and FP ops use the B-pipe.
7 ;; Integer ALU ops can use either pipe.
9 (define_cpu_unit "sifive_7_A" "sifive_7")
10 (define_cpu_unit "sifive_7_B" "sifive_7")
12 (define_cpu_unit "sifive_7_idiv" "sifive_7")
13 (define_cpu_unit "sifive_7_fpu" "sifive_7")
15 (define_insn_reservation "sifive_7_load" 3
16 (and (eq_attr "tune" "sifive_7")
17 (eq_attr "type" "load"))
20 (define_insn_reservation "sifive_7_fpload" 2
21 (and (eq_attr "tune" "sifive_7")
22 (eq_attr "type" "fpload"))
25 (define_insn_reservation "sifive_7_store" 1
26 (and (eq_attr "tune" "sifive_7")
27 (eq_attr "type" "store"))
30 (define_insn_reservation "sifive_7_fpstore" 1
31 (and (eq_attr "tune" "sifive_7")
32 (eq_attr "type" "fpstore"))
35 (define_insn_reservation "sifive_7_branch" 1
36 (and (eq_attr "tune" "sifive_7")
37 (eq_attr "type" "branch"))
40 (define_insn_reservation "sifive_7_jump" 1
41 (and (eq_attr "tune" "sifive_7")
42 (eq_attr "type" "jump,call"))
45 (define_insn_reservation "sifive_7_mul" 3
46 (and (eq_attr "tune" "sifive_7")
47 (eq_attr "type" "imul"))
50 (define_insn_reservation "sifive_7_div" 16
51 (and (eq_attr "tune" "sifive_7")
52 (eq_attr "type" "idiv"))
53 "sifive_7_B,sifive_7_idiv*15")
55 (define_insn_reservation "sifive_7_alu" 2
56 (and (eq_attr "tune" "sifive_7")
57 (eq_attr "type" "unknown,arith,shift,slt,multi,logical,move"))
58 "sifive_7_A|sifive_7_B")
60 (define_insn_reservation "sifive_7_load_immediate" 1
61 (and (eq_attr "tune" "sifive_7")
62 (eq_attr "type" "nop,const,auipc"))
63 "sifive_7_A|sifive_7_B")
65 (define_insn_reservation "sifive_7_sfma" 5
66 (and (eq_attr "tune" "sifive_7")
67 (and (eq_attr "type" "fadd,fmul,fmadd")
68 (eq_attr "mode" "SF")))
71 (define_insn_reservation "sifive_7_dfma" 7
72 (and (eq_attr "tune" "sifive_7")
73 (and (eq_attr "type" "fadd,fmul,fmadd")
74 (eq_attr "mode" "DF")))
77 (define_insn_reservation "sifive_7_fp_other" 3
78 (and (eq_attr "tune" "sifive_7")
79 (eq_attr "type" "fcvt,fcmp,fmove"))
82 (define_insn_reservation "sifive_7_fdiv_s" 27
83 (and (eq_attr "tune" "sifive_7")
84 (eq_attr "type" "fdiv,fsqrt")
85 (eq_attr "mode" "SF"))
86 "sifive_7_B,sifive_7_fpu*26")
88 (define_insn_reservation "sifive_7_fdiv_d" 56
89 (and (eq_attr "tune" "sifive_7")
90 (eq_attr "type" "fdiv,fsqrt")
91 (eq_attr "mode" "DF"))
92 "sifive_7_B,sifive_7_fpu*55")
94 (define_insn_reservation "sifive_7_i2f" 3
95 (and (eq_attr "tune" "sifive_7")
96 (eq_attr "type" "mtc"))
99 (define_insn_reservation "sifive_7_f2i" 3
100 (and (eq_attr "tune" "sifive_7")
101 (eq_attr "type" "mfc"))
104 (define_bypass 1 "sifive_7_load,sifive_7_alu,sifive_7_mul,sifive_7_f2i"
105 "sifive_7_alu,sifive_7_branch")
107 (define_bypass 1 "sifive_7_load,sifive_7_alu,sifive_7_mul,sifive_7_f2i"
108 "sifive_7_store" "riscv_store_data_bypass_p")
110 (define_bypass 2 "sifive_7_i2f"
111 "sifive_7_sfma,sifive_7_dfma,sifive_7_fp_other,sifive_7_fdiv_s,sifive_7_fdiv_d")
113 (define_bypass 2 "sifive_7_fp_other"
114 "sifive_7_sfma,sifive_7_dfma,sifive_7_fp_other,sifive_7_fdiv_s,sifive_7_fdiv_d")
116 (define_bypass 2 "sifive_7_fp_other"
117 "sifive_7_alu,sifive_7_branch")
119 (define_bypass 2 "sifive_7_fp_other"
120 "sifive_7_store" "riscv_store_data_bypass_p")