Lines Matching refs:outs
76 def FP32_TO_INT16_IN_MEM : PseudoI<(outs), (ins i16mem:$dst, RFP32:$src),
78 def FP32_TO_INT32_IN_MEM : PseudoI<(outs), (ins i32mem:$dst, RFP32:$src),
80 def FP32_TO_INT64_IN_MEM : PseudoI<(outs), (ins i64mem:$dst, RFP32:$src),
82 def FP64_TO_INT16_IN_MEM : PseudoI<(outs), (ins i16mem:$dst, RFP64:$src),
84 def FP64_TO_INT32_IN_MEM : PseudoI<(outs), (ins i32mem:$dst, RFP64:$src),
86 def FP64_TO_INT64_IN_MEM : PseudoI<(outs), (ins i64mem:$dst, RFP64:$src),
88 def FP80_TO_INT16_IN_MEM : PseudoI<(outs), (ins i16mem:$dst, RFP80:$src),
90 def FP80_TO_INT32_IN_MEM : PseudoI<(outs), (ins i32mem:$dst, RFP80:$src),
92 def FP80_TO_INT64_IN_MEM : PseudoI<(outs), (ins i64mem:$dst, RFP80:$src),
116 def FpPOP_RETVAL : FpI_<(outs RFP80:$dst), (ins), SpecialFP, []>;
122 class FpIf32<dag outs, dag ins, FPFormat fp, list<dag> pattern> :
123 FpI_<outs, ins, fp, pattern>, Requires<[FPStackf32]>;
124 class FpIf64<dag outs, dag ins, FPFormat fp, list<dag> pattern> :
125 FpI_<outs, ins, fp, pattern>, Requires<[FPStackf64]>;
131 def _Fp32 : FpIf32<(outs RFP32:$dst), (ins RFP32:$src1, RFP32:$src2), TwoArgFP,
133 def _Fp64 : FpIf64<(outs RFP64:$dst), (ins RFP64:$src1, RFP64:$src2), TwoArgFP,
135 def _Fp80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src1, RFP80:$src2), TwoArgFP,
143 def _Fp32m : FpIf32<(outs RFP32:$dst),
147 def _Fp64m : FpIf64<(outs RFP64:$dst),
151 def _Fp64m32: FpIf64<(outs RFP64:$dst),
155 def _Fp80m32: FpI_<(outs RFP80:$dst),
159 def _Fp80m64: FpI_<(outs RFP80:$dst),
163 def _F32m : FPI<0xD8, fp, (outs), (ins f32mem:$src),
167 def _F64m : FPI<0xDC, fp, (outs), (ins f64mem:$src),
172 def _FpI16m32 : FpIf32<(outs RFP32:$dst), (ins RFP32:$src1, i16mem:$src2),
176 def _FpI32m32 : FpIf32<(outs RFP32:$dst), (ins RFP32:$src1, i32mem:$src2),
180 def _FpI16m64 : FpIf64<(outs RFP64:$dst), (ins RFP64:$src1, i16mem:$src2),
184 def _FpI32m64 : FpIf64<(outs RFP64:$dst), (ins RFP64:$src1, i32mem:$src2),
188 def _FpI16m80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src1, i16mem:$src2),
192 def _FpI32m80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src1, i32mem:$src2),
196 def _FI16m : FPI<0xDE, fp, (outs), (ins i16mem:$src),
200 def _FI32m : FPI<0xDA, fp, (outs), (ins i32mem:$src),
218 : FPI<o, AddRegFrm, (outs), (ins RST:$op), asm>, D8;
220 : FPI<o, AddRegFrm, (outs), (ins RST:$op), asm>, DC;
222 : FPI<o, AddRegFrm, (outs), (ins RST:$op), asm>, DE;
251 def _Fp32 : FpIf32<(outs RFP32:$dst), (ins RFP32:$src), OneArgFPRW,
253 def _Fp64 : FpIf64<(outs RFP64:$dst), (ins RFP64:$src), OneArgFPRW,
255 def _Fp80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src), OneArgFPRW,
257 def _F : FPI<opcode, RawFrm, (outs), (ins), asmstring>, D9;
267 def TST_Fp32 : FpIf32<(outs), (ins RFP32:$src), OneArgFP, []>;
268 def TST_Fp64 : FpIf64<(outs), (ins RFP64:$src), OneArgFP, []>;
269 def TST_Fp80 : FpI_<(outs), (ins RFP80:$src), OneArgFP, []>;
271 def TST_F : FPI<0xE4, RawFrm, (outs), (ins), "ftst">, D9;
275 def FCOM32m : FPI<0xD8, MRM2m, (outs), (ins f32mem:$src), "fcom{s}\t$src">;
276 def FCOMP32m : FPI<0xD8, MRM3m, (outs), (ins f32mem:$src), "fcomp{s}\t$src">;
278 def FLDENVm : FPI<0xD9, MRM4m, (outs), (ins f32mem:$src), "fldenv\t$src">;
279 def FSTENVm : FPI<0xD9, MRM6m, (outs f32mem:$dst), (ins), "fnstenv\t$dst">;
281 def FICOM32m : FPI<0xDA, MRM2m, (outs), (ins i32mem:$src), "ficom{l}\t$src">;
282 def FICOMP32m: FPI<0xDA, MRM3m, (outs), (ins i32mem:$src), "ficomp{l}\t$src">;
284 def FCOM64m : FPI<0xDC, MRM2m, (outs), (ins f64mem:$src), "fcom{l}\t$src">;
285 def FCOMP64m : FPI<0xDC, MRM3m, (outs), (ins f64mem:$src), "fcomp{l}\t$src">;
287 def FRSTORm : FPI<0xDD, MRM4m, (outs f32mem:$dst), (ins), "frstor\t$dst">;
288 def FSAVEm : FPI<0xDD, MRM6m, (outs f32mem:$dst), (ins), "fnsave\t$dst">;
289 def FNSTSWm : FPI<0xDD, MRM7m, (outs f32mem:$dst), (ins), "fnstsw\t$dst">;
291 def FICOM16m : FPI<0xDE, MRM2m, (outs), (ins i16mem:$src), "ficom{s}\t$src">;
292 def FICOMP16m: FPI<0xDE, MRM3m, (outs), (ins i16mem:$src), "ficomp{s}\t$src">;
294 def FBLDm : FPI<0xDF, MRM4m, (outs), (ins f32mem:$src), "fbld\t$src">;
295 def FBSTPm : FPI<0xDF, MRM6m, (outs f32mem:$dst), (ins), "fbstp\t$dst">;
298 class FpIf32CMov<dag outs, dag ins, FPFormat fp, list<dag> pattern> :
299 FpI_<outs, ins, fp, pattern>, Requires<[FPStackf32, HasCMov]>;
300 class FpIf64CMov<dag outs, dag ins, FPFormat fp, list<dag> pattern> :
301 FpI_<outs, ins, fp, pattern>, Requires<[FPStackf64, HasCMov]>;
304 def _Fp32 : FpIf32CMov<(outs RFP32:$dst), (ins RFP32:$src1, RFP32:$src2),
308 def _Fp64 : FpIf64CMov<(outs RFP64:$dst), (ins RFP64:$src1, RFP64:$src2),
312 def _Fp80 : FpI_<(outs RFP80:$dst), (ins RFP80:$src1, RFP80:$src2),
332 def CMOVB_F : FPI<0xC0, AddRegFrm, (outs RST:$op), (ins),
334 def CMOVBE_F : FPI<0xD0, AddRegFrm, (outs RST:$op), (ins),
336 def CMOVE_F : FPI<0xC8, AddRegFrm, (outs RST:$op), (ins),
338 def CMOVP_F : FPI<0xD8, AddRegFrm, (outs RST:$op), (ins),
340 def CMOVNB_F : FPI<0xC0, AddRegFrm, (outs RST:$op), (ins),
342 def CMOVNBE_F: FPI<0xD0, AddRegFrm, (outs RST:$op), (ins),
344 def CMOVNE_F : FPI<0xC8, AddRegFrm, (outs RST:$op), (ins),
346 def CMOVNP_F : FPI<0xD8, AddRegFrm, (outs RST:$op), (ins),
352 def LD_Fp32m : FpIf32<(outs RFP32:$dst), (ins f32mem:$src), ZeroArgFP,
355 def LD_Fp64m : FpIf64<(outs RFP64:$dst), (ins f64mem:$src), ZeroArgFP,
357 def LD_Fp80m : FpI_<(outs RFP80:$dst), (ins f80mem:$src), ZeroArgFP,
360 def LD_Fp32m64 : FpIf64<(outs RFP64:$dst), (ins f32mem:$src), ZeroArgFP,
362 def LD_Fp64m80 : FpI_<(outs RFP80:$dst), (ins f64mem:$src), ZeroArgFP,
364 def LD_Fp32m80 : FpI_<(outs RFP80:$dst), (ins f32mem:$src), ZeroArgFP,
366 def ILD_Fp16m32: FpIf32<(outs RFP32:$dst), (ins i16mem:$src), ZeroArgFP,
368 def ILD_Fp32m32: FpIf32<(outs RFP32:$dst), (ins i32mem:$src), ZeroArgFP,
370 def ILD_Fp64m32: FpIf32<(outs RFP32:$dst), (ins i64mem:$src), ZeroArgFP,
372 def ILD_Fp16m64: FpIf64<(outs RFP64:$dst), (ins i16mem:$src), ZeroArgFP,
374 def ILD_Fp32m64: FpIf64<(outs RFP64:$dst), (ins i32mem:$src), ZeroArgFP,
376 def ILD_Fp64m64: FpIf64<(outs RFP64:$dst), (ins i64mem:$src), ZeroArgFP,
378 def ILD_Fp16m80: FpI_<(outs RFP80:$dst), (ins i16mem:$src), ZeroArgFP,
380 def ILD_Fp32m80: FpI_<(outs RFP80:$dst), (ins i32mem:$src), ZeroArgFP,
382 def ILD_Fp64m80: FpI_<(outs RFP80:$dst), (ins i64mem:$src), ZeroArgFP,
385 def ST_Fp32m : FpIf32<(outs), (ins f32mem:$op, RFP32:$src), OneArgFP,
387 def ST_Fp64m32 : FpIf64<(outs), (ins f32mem:$op, RFP64:$src), OneArgFP,
389 def ST_Fp64m : FpIf64<(outs), (ins f64mem:$op, RFP64:$src), OneArgFP,
391 def ST_Fp80m32 : FpI_<(outs), (ins f32mem:$op, RFP80:$src), OneArgFP,
393 def ST_Fp80m64 : FpI_<(outs), (ins f64mem:$op, RFP80:$src), OneArgFP,
398 def ST_FpP32m : FpIf32<(outs), (ins f32mem:$op, RFP32:$src), OneArgFP, []>;
399 def ST_FpP64m32 : FpIf64<(outs), (ins f32mem:$op, RFP64:$src), OneArgFP, []>;
400 def ST_FpP64m : FpIf64<(outs), (ins f64mem:$op, RFP64:$src), OneArgFP, []>;
401 def ST_FpP80m32 : FpI_<(outs), (ins f32mem:$op, RFP80:$src), OneArgFP, []>;
402 def ST_FpP80m64 : FpI_<(outs), (ins f64mem:$op, RFP80:$src), OneArgFP, []>;
404 def ST_FpP80m : FpI_<(outs), (ins f80mem:$op, RFP80:$src), OneArgFP,
407 def IST_Fp16m32 : FpIf32<(outs), (ins i16mem:$op, RFP32:$src), OneArgFP, []>;
408 def IST_Fp32m32 : FpIf32<(outs), (ins i32mem:$op, RFP32:$src), OneArgFP, []>;
409 def IST_Fp64m32 : FpIf32<(outs), (ins i64mem:$op, RFP32:$src), OneArgFP, []>;
410 def IST_Fp16m64 : FpIf64<(outs), (ins i16mem:$op, RFP64:$src), OneArgFP, []>;
411 def IST_Fp32m64 : FpIf64<(outs), (ins i32mem:$op, RFP64:$src), OneArgFP, []>;
412 def IST_Fp64m64 : FpIf64<(outs), (ins i64mem:$op, RFP64:$src), OneArgFP, []>;
413 def IST_Fp16m80 : FpI_<(outs), (ins i16mem:$op, RFP80:$src), OneArgFP, []>;
414 def IST_Fp32m80 : FpI_<(outs), (ins i32mem:$op, RFP80:$src), OneArgFP, []>;
415 def IST_Fp64m80 : FpI_<(outs), (ins i64mem:$op, RFP80:$src), OneArgFP, []>;
419 def LD_F32m : FPI<0xD9, MRM0m, (outs), (ins f32mem:$src), "fld{s}\t$src">;
420 def LD_F64m : FPI<0xDD, MRM0m, (outs), (ins f64mem:$src), "fld{l}\t$src">;
421 def LD_F80m : FPI<0xDB, MRM5m, (outs), (ins f80mem:$src), "fld{t}\t$src">;
422 def ILD_F16m : FPI<0xDF, MRM0m, (outs), (ins i16mem:$src), "fild{s}\t$src">;
423 def ILD_F32m : FPI<0xDB, MRM0m, (outs), (ins i32mem:$src), "fild{l}\t$src">;
424 def ILD_F64m : FPI<0xDF, MRM5m, (outs), (ins i64mem:$src), "fild{ll}\t$src">;
427 def ST_F32m : FPI<0xD9, MRM2m, (outs), (ins f32mem:$dst), "fst{s}\t$dst">;
428 def ST_F64m : FPI<0xDD, MRM2m, (outs), (ins f64mem:$dst), "fst{l}\t$dst">;
429 def ST_FP32m : FPI<0xD9, MRM3m, (outs), (ins f32mem:$dst), "fstp{s}\t$dst">;
430 def ST_FP64m : FPI<0xDD, MRM3m, (outs), (ins f64mem:$dst), "fstp{l}\t$dst">;
431 def ST_FP80m : FPI<0xDB, MRM7m, (outs), (ins f80mem:$dst), "fstp{t}\t$dst">;
432 def IST_F16m : FPI<0xDF, MRM2m, (outs), (ins i16mem:$dst), "fist{s}\t$dst">;
433 def IST_F32m : FPI<0xDB, MRM2m, (outs), (ins i32mem:$dst), "fist{l}\t$dst">;
434 def IST_FP16m : FPI<0xDF, MRM3m, (outs), (ins i16mem:$dst), "fistp{s}\t$dst">;
435 def IST_FP32m : FPI<0xDB, MRM3m, (outs), (ins i32mem:$dst), "fistp{l}\t$dst">;
436 def IST_FP64m : FPI<0xDF, MRM7m, (outs), (ins i64mem:$dst), "fistp{ll}\t$dst">;
441 def ISTT_Fp16m32 : FpI_<(outs), (ins i16mem:$op, RFP32:$src), OneArgFP,
443 def ISTT_Fp32m32 : FpI_<(outs), (ins i32mem:$op, RFP32:$src), OneArgFP,
445 def ISTT_Fp64m32 : FpI_<(outs), (ins i64mem:$op, RFP32:$src), OneArgFP,
447 def ISTT_Fp16m64 : FpI_<(outs), (ins i16mem:$op, RFP64:$src), OneArgFP,
449 def ISTT_Fp32m64 : FpI_<(outs), (ins i32mem:$op, RFP64:$src), OneArgFP,
451 def ISTT_Fp64m64 : FpI_<(outs), (ins i64mem:$op, RFP64:$src), OneArgFP,
453 def ISTT_Fp16m80 : FpI_<(outs), (ins i16mem:$op, RFP80:$src), OneArgFP,
455 def ISTT_Fp32m80 : FpI_<(outs), (ins i32mem:$op, RFP80:$src), OneArgFP,
457 def ISTT_Fp64m80 : FpI_<(outs), (ins i64mem:$op, RFP80:$src), OneArgFP,
462 def ISTT_FP16m : FPI<0xDF, MRM1m, (outs), (ins i16mem:$dst), "fisttp{s}\t$dst">;
463 def ISTT_FP32m : FPI<0xDB, MRM1m, (outs), (ins i32mem:$dst), "fisttp{l}\t$dst">;
464 def ISTT_FP64m : FPI<0xDD, MRM1m, (outs), (ins i64mem:$dst),
469 def LD_Frr : FPI<0xC0, AddRegFrm, (outs), (ins RST:$op), "fld\t$op">, D9;
470 def ST_Frr : FPI<0xD0, AddRegFrm, (outs), (ins RST:$op), "fst\t$op">, DD;
471 def ST_FPrr : FPI<0xD8, AddRegFrm, (outs), (ins RST:$op), "fstp\t$op">, DD;
472 def XCH_F : FPI<0xC8, AddRegFrm, (outs), (ins RST:$op), "fxch\t$op">, D9;
476 def LD_Fp032 : FpIf32<(outs RFP32:$dst), (ins), ZeroArgFP,
478 def LD_Fp132 : FpIf32<(outs RFP32:$dst), (ins), ZeroArgFP,
480 def LD_Fp064 : FpIf64<(outs RFP64:$dst), (ins), ZeroArgFP,
482 def LD_Fp164 : FpIf64<(outs RFP64:$dst), (ins), ZeroArgFP,
484 def LD_Fp080 : FpI_<(outs RFP80:$dst), (ins), ZeroArgFP,
486 def LD_Fp180 : FpI_<(outs RFP80:$dst), (ins), ZeroArgFP,
490 def LD_F0 : FPI<0xEE, RawFrm, (outs), (ins), "fldz">, D9;
491 def LD_F1 : FPI<0xE8, RawFrm, (outs), (ins), "fld1">, D9;
496 def UCOM_Fpr32 : FpIf32<(outs), (ins RFP32:$lhs, RFP32:$rhs), CompareFP,
498 def UCOM_Fpr64 : FpIf64<(outs), (ins RFP64:$lhs, RFP64:$rhs), CompareFP,
500 def UCOM_Fpr80 : FpI_ <(outs), (ins RFP80:$lhs, RFP80:$rhs), CompareFP,
504 def UCOM_FpIr32: FpIf32<(outs), (ins RFP32:$lhs, RFP32:$rhs), CompareFP,
506 def UCOM_FpIr64: FpIf64<(outs), (ins RFP64:$lhs, RFP64:$rhs), CompareFP,
508 def UCOM_FpIr80: FpI_<(outs), (ins RFP80:$lhs, RFP80:$rhs), CompareFP,
514 (outs), (ins RST:$reg),
517 (outs), (ins RST:$reg),
520 (outs), (ins),
524 (outs), (ins RST:$reg),
527 (outs), (ins RST:$reg),
531 def COM_FIr : FPI<0xF0, AddRegFrm, (outs), (ins RST:$reg),
533 def COM_FIPr : FPI<0xF0, AddRegFrm, (outs), (ins RST:$reg),
539 (outs), (ins), "fnstsw %ax", []>, DF;
542 (outs), (ins i16mem:$dst), "fnstcw\t$dst",
547 (outs), (ins i16mem:$dst), "fldcw\t$dst", []>;
550 def FNINIT : I<0xE3, RawFrm, (outs), (ins), "fninit", []>, DB;
551 def FFREE : FPI<0xC0, AddRegFrm, (outs), (ins RST:$reg),
556 def FNCLEX : I<0xE2, RawFrm, (outs), (ins), "fnclex", []>, DB;
559 def WAIT : I<0x9B, RawFrm, (outs), (ins), "wait", []>;
561 def FNOP : I<0xD0, RawFrm, (outs), (ins), "fnop", []>, D9;
562 def FXAM : I<0xE5, RawFrm, (outs), (ins), "fxam", []>, D9;
563 def FLDL2T : I<0xE9, RawFrm, (outs), (ins), "fldl2t", []>, D9;
564 def FLDL2E : I<0xEA, RawFrm, (outs), (ins), "fldl2e", []>, D9;
565 def FLDPI : I<0xEB, RawFrm, (outs), (ins), "fldpi", []>, D9;
566 def FLDLG2 : I<0xEC, RawFrm, (outs), (ins), "fldlg2", []>, D9;
567 def FLDLN2 : I<0xED, RawFrm, (outs), (ins), "fldln2", []>, D9;
568 def F2XM1 : I<0xF0, RawFrm, (outs), (ins), "f2xm1", []>, D9;
569 def FYL2X : I<0xF1, RawFrm, (outs), (ins), "fyl2x", []>, D9;
570 def FPTAN : I<0xF2, RawFrm, (outs), (ins), "fptan", []>, D9;
571 def FPATAN : I<0xF3, RawFrm, (outs), (ins), "fpatan", []>, D9;
572 def FXTRACT : I<0xF4, RawFrm, (outs), (ins), "fxtract", []>, D9;
573 def FPREM1 : I<0xF5, RawFrm, (outs), (ins), "fprem1", []>, D9;
574 def FDECSTP : I<0xF6, RawFrm, (outs), (ins), "fdecstp", []>, D9;
575 def FINCSTP : I<0xF7, RawFrm, (outs), (ins), "fincstp", []>, D9;
576 def FPREM : I<0xF8, RawFrm, (outs), (ins), "fprem", []>, D9;
577 def FYL2XP1 : I<0xF9, RawFrm, (outs), (ins), "fyl2xp1", []>, D9;
578 def FSINCOS : I<0xFB, RawFrm, (outs), (ins), "fsincos", []>, D9;
579 def FRNDINT : I<0xFC, RawFrm, (outs), (ins), "frndint", []>, D9;
580 def FSCALE : I<0xFD, RawFrm, (outs), (ins), "fscale", []>, D9;
581 def FCOMPP : I<0xD9, RawFrm, (outs), (ins), "fcompp", []>, DE;
583 def FXSAVE : I<0xAE, MRM0m, (outs opaque512mem:$dst), (ins),
585 def FXSAVE64 : I<0xAE, MRM0m, (outs opaque512mem:$dst), (ins),
587 def FXRSTOR : I<0xAE, MRM1m, (outs), (ins opaque512mem:$src),
589 def FXRSTOR64 : I<0xAE, MRM1m, (outs), (ins opaque512mem:$src),