• Home
  • Raw
  • Download

Lines Matching refs:Pat

17 def : Pat<(atomic_fence (i64 4), (imm)), (DMB (i32 0x9))>;
18 def : Pat<(atomic_fence (imm), (imm)), (DMB (i32 0xb))>;
44 def : Pat<(acquiring_load<atomic_load_8> GPR64sp:$ptr), (LDARB GPR64sp:$ptr)>;
45 def : Pat<(relaxed_load<atomic_load_8> (ro_Windexed8 GPR64sp:$Rn, GPR32:$Rm,
48 def : Pat<(relaxed_load<atomic_load_8> (ro_Xindexed8 GPR64sp:$Rn, GPR64:$Rm,
51 def : Pat<(relaxed_load<atomic_load_8> (am_indexed8 GPR64sp:$Rn,
54 def : Pat<(relaxed_load<atomic_load_8>
59 def : Pat<(acquiring_load<atomic_load_16> GPR64sp:$ptr), (LDARH GPR64sp:$ptr)>;
60 def : Pat<(relaxed_load<atomic_load_16> (ro_Windexed16 GPR64sp:$Rn, GPR32:$Rm,
63 def : Pat<(relaxed_load<atomic_load_16> (ro_Xindexed16 GPR64sp:$Rn, GPR64:$Rm,
66 def : Pat<(relaxed_load<atomic_load_16> (am_indexed16 GPR64sp:$Rn,
69 def : Pat<(relaxed_load<atomic_load_16>
74 def : Pat<(acquiring_load<atomic_load_32> GPR64sp:$ptr), (LDARW GPR64sp:$ptr)>;
75 def : Pat<(relaxed_load<atomic_load_32> (ro_Windexed32 GPR64sp:$Rn, GPR32:$Rm,
78 def : Pat<(relaxed_load<atomic_load_32> (ro_Xindexed32 GPR64sp:$Rn, GPR64:$Rm,
81 def : Pat<(relaxed_load<atomic_load_32> (am_indexed32 GPR64sp:$Rn,
84 def : Pat<(relaxed_load<atomic_load_32>
89 def : Pat<(acquiring_load<atomic_load_64> GPR64sp:$ptr), (LDARX GPR64sp:$ptr)>;
90 def : Pat<(relaxed_load<atomic_load_64> (ro_Windexed64 GPR64sp:$Rn, GPR32:$Rm,
93 def : Pat<(relaxed_load<atomic_load_64> (ro_Xindexed64 GPR64sp:$Rn, GPR64:$Rm,
96 def : Pat<(relaxed_load<atomic_load_64> (am_indexed64 GPR64sp:$Rn,
99 def : Pat<(relaxed_load<atomic_load_64>
128 def : Pat<(releasing_store<atomic_store_8> GPR64sp:$ptr, GPR32:$val),
130 def : Pat<(relaxed_store<atomic_store_8>
134 def : Pat<(relaxed_store<atomic_store_8>
138 def : Pat<(relaxed_store<atomic_store_8>
141 def : Pat<(relaxed_store<atomic_store_8>
146 def : Pat<(releasing_store<atomic_store_16> GPR64sp:$ptr, GPR32:$val),
148 def : Pat<(relaxed_store<atomic_store_16> (ro_Windexed16 GPR64sp:$Rn, GPR32:$Rm,
152 def : Pat<(relaxed_store<atomic_store_16> (ro_Xindexed16 GPR64sp:$Rn, GPR64:$Rm,
156 def : Pat<(relaxed_store<atomic_store_16>
159 def : Pat<(relaxed_store<atomic_store_16>
164 def : Pat<(releasing_store<atomic_store_32> GPR64sp:$ptr, GPR32:$val),
166 def : Pat<(relaxed_store<atomic_store_32> (ro_Windexed32 GPR64sp:$Rn, GPR32:$Rm,
170 def : Pat<(relaxed_store<atomic_store_32> (ro_Xindexed32 GPR64sp:$Rn, GPR64:$Rm,
174 def : Pat<(relaxed_store<atomic_store_32>
177 def : Pat<(relaxed_store<atomic_store_32>
182 def : Pat<(releasing_store<atomic_store_64> GPR64sp:$ptr, GPR64:$val),
184 def : Pat<(relaxed_store<atomic_store_64> (ro_Windexed64 GPR64sp:$Rn, GPR32:$Rm,
188 def : Pat<(relaxed_store<atomic_store_64> (ro_Xindexed64 GPR64sp:$Rn, GPR64:$Rm,
192 def : Pat<(relaxed_store<atomic_store_64>
195 def : Pat<(relaxed_store<atomic_store_64>
221 def : Pat<(ldxr_1 GPR64sp:$addr),
223 def : Pat<(ldxr_2 GPR64sp:$addr),
225 def : Pat<(ldxr_4 GPR64sp:$addr),
227 def : Pat<(ldxr_8 GPR64sp:$addr), (LDXRX GPR64sp:$addr)>;
229 def : Pat<(and (ldxr_1 GPR64sp:$addr), 0xff),
231 def : Pat<(and (ldxr_2 GPR64sp:$addr), 0xffff),
233 def : Pat<(and (ldxr_4 GPR64sp:$addr), 0xffffffff),
254 def : Pat<(ldaxr_1 GPR64sp:$addr),
256 def : Pat<(ldaxr_2 GPR64sp:$addr),
258 def : Pat<(ldaxr_4 GPR64sp:$addr),
260 def : Pat<(ldaxr_8 GPR64sp:$addr), (LDAXRX GPR64sp:$addr)>;
262 def : Pat<(and (ldaxr_1 GPR64sp:$addr), 0xff),
264 def : Pat<(and (ldaxr_2 GPR64sp:$addr), 0xffff),
266 def : Pat<(and (ldaxr_4 GPR64sp:$addr), 0xffffffff),
292 def : Pat<(stxr_1 GPR64:$val, GPR64sp:$addr),
294 def : Pat<(stxr_2 GPR64:$val, GPR64sp:$addr),
296 def : Pat<(stxr_4 GPR64:$val, GPR64sp:$addr),
298 def : Pat<(stxr_8 GPR64:$val, GPR64sp:$addr),
301 def : Pat<(stxr_1 (zext (and GPR32:$val, 0xff)), GPR64sp:$addr),
303 def : Pat<(stxr_2 (zext (and GPR32:$val, 0xffff)), GPR64sp:$addr),
305 def : Pat<(stxr_4 (zext GPR32:$val), GPR64sp:$addr),
308 def : Pat<(stxr_1 (and GPR64:$val, 0xff), GPR64sp:$addr),
310 def : Pat<(stxr_2 (and GPR64:$val, 0xffff), GPR64sp:$addr),
312 def : Pat<(stxr_4 (and GPR64:$val, 0xffffffff), GPR64sp:$addr),
338 def : Pat<(stlxr_1 GPR64:$val, GPR64sp:$addr),
340 def : Pat<(stlxr_2 GPR64:$val, GPR64sp:$addr),
342 def : Pat<(stlxr_4 GPR64:$val, GPR64sp:$addr),
344 def : Pat<(stlxr_8 GPR64:$val, GPR64sp:$addr),
347 def : Pat<(stlxr_1 (zext (and GPR32:$val, 0xff)), GPR64sp:$addr),
349 def : Pat<(stlxr_2 (zext (and GPR32:$val, 0xffff)), GPR64sp:$addr),
351 def : Pat<(stlxr_4 (zext GPR32:$val), GPR64sp:$addr),
354 def : Pat<(stlxr_1 (and GPR64:$val, 0xff), GPR64sp:$addr),
356 def : Pat<(stlxr_2 (and GPR64:$val, 0xffff), GPR64sp:$addr),
358 def : Pat<(stlxr_4 (and GPR64:$val, 0xffffffff), GPR64sp:$addr),
364 def : Pat<(int_aarch64_clrex), (CLREX 0xf)>;