207 const unsigned Opc =
MI.getOpcode();
223 assert((GPRSize == 32 || GPRSize == 64) &&
"Unexpected GPR size");
225 unsigned NumOperands =
MI.getNumOperands();
231 case TargetOpcode::G_ADD:
232 case TargetOpcode::G_SUB:
233 case TargetOpcode::G_SHL:
234 case TargetOpcode::G_ASHR:
235 case TargetOpcode::G_LSHR:
236 case TargetOpcode::G_AND:
237 case TargetOpcode::G_OR:
238 case TargetOpcode::G_XOR:
239 case TargetOpcode::G_MUL:
240 case TargetOpcode::G_SDIV:
241 case TargetOpcode::G_SREM:
242 case TargetOpcode::G_SMULH:
243 case TargetOpcode::G_SMAX:
244 case TargetOpcode::G_SMIN:
245 case TargetOpcode::G_UDIV:
246 case TargetOpcode::G_UREM:
247 case TargetOpcode::G_UMULH:
248 case TargetOpcode::G_UMAX:
249 case TargetOpcode::G_UMIN:
250 case TargetOpcode::G_PTR_ADD:
251 case TargetOpcode::G_PTRTOINT:
252 case TargetOpcode::G_INTTOPTR:
253 case TargetOpcode::G_FADD:
254 case TargetOpcode::G_FSUB:
255 case TargetOpcode::G_FMUL:
256 case TargetOpcode::G_FDIV:
257 case TargetOpcode::G_FABS:
258 case TargetOpcode::G_FNEG:
259 case TargetOpcode::G_FSQRT:
260 case TargetOpcode::G_FMAXNUM:
261 case TargetOpcode::G_FMINNUM: {
262 LLT Ty =
MRI.getType(
MI.getOperand(0).getReg());
271 Mapping = GPRValueMapping;
275 for (
unsigned Idx = 1; Idx != NumOperands; ++Idx) {
276 LLT OpTy =
MRI.getType(
MI.getOperand(Idx).getReg());
278 "Operand has incompatible type");
287 case TargetOpcode::G_SEXTLOAD:
288 case TargetOpcode::G_ZEXTLOAD:
291 case TargetOpcode::G_IMPLICIT_DEF: {
293 LLT DstTy =
MRI.getType(Dst);
295 auto Mapping = GPRValueMapping;
303 else if (anyUseOnlyUseFP(Dst,
MRI,
TRI))
314 case TargetOpcode::G_LOAD: {
315 LLT Ty =
MRI.getType(
MI.getOperand(0).getReg());
318 OpdsMapping[1] = GPRValueMapping;
325 OpdsMapping[0] = GPRValueMapping;
328 if (GPRSize == 32 &&
Size.getFixedValue() == 64) {
337 if (anyUseOnlyUseFP(
MI.getOperand(0).getReg(),
MRI,
TRI)) {
348 case TargetOpcode::G_STORE: {
349 LLT Ty =
MRI.getType(
MI.getOperand(0).getReg());
352 OpdsMapping[1] = GPRValueMapping;
359 OpdsMapping[0] = GPRValueMapping;
362 if (GPRSize == 32 &&
Size.getFixedValue() == 64) {
373 case TargetOpcode::G_SELECT: {
374 LLT Ty =
MRI.getType(
MI.getOperand(0).getReg());
378 LLT TestTy =
MRI.getType(Sel.getCondReg());
379 assert(TestTy.
isVector() &&
"Unexpected condition argument type");
380 OpdsMapping[0] = OpdsMapping[2] = OpdsMapping[3] =
393 if (GPRSize == 32 && Ty.getSizeInBits() == 64) {
402 if (
any_of(
MRI.use_nodbg_instructions(
MI.getOperand(0).getReg()),
404 return onlyUsesFP(UseMI, MRI, TRI);
421 for (
unsigned Idx = 2; Idx < 4; ++Idx) {
431 OpdsMapping[1] = GPRValueMapping;
437 OpdsMapping[0] = OpdsMapping[2] = OpdsMapping[3] = Mapping;
440 case RISCV::G_FCVT_W_RV64:
441 case RISCV::G_FCVT_WU_RV64:
442 case TargetOpcode::G_FPTOSI:
443 case TargetOpcode::G_FPTOUI:
444 case RISCV::G_FCLASS: {
445 LLT Ty =
MRI.getType(
MI.getOperand(1).getReg());
446 OpdsMapping[0] = GPRValueMapping;
450 case TargetOpcode::G_SITOFP:
451 case TargetOpcode::G_UITOFP: {
452 LLT Ty =
MRI.getType(
MI.getOperand(0).getReg());
454 OpdsMapping[1] = GPRValueMapping;
457 case TargetOpcode::G_FCMP: {
458 LLT Ty =
MRI.getType(
MI.getOperand(2).getReg());
460 unsigned Size = Ty.getSizeInBits();
462 OpdsMapping[0] = GPRValueMapping;
466 case TargetOpcode::G_MERGE_VALUES: {
468 LLT Ty =
MRI.getType(
MI.getOperand(0).getReg());
469 if (GPRSize == 32 && Ty.getSizeInBits() == 64) {
472 OpdsMapping[1] = GPRValueMapping;
473 OpdsMapping[2] = GPRValueMapping;
477 case TargetOpcode::G_UNMERGE_VALUES: {
479 LLT Ty =
MRI.getType(
MI.getOperand(2).getReg());
480 if (GPRSize == 32 && Ty.getSizeInBits() == 64) {
482 OpdsMapping[0] = GPRValueMapping;
483 OpdsMapping[1] = GPRValueMapping;
488 case TargetOpcode::G_SPLAT_VECTOR: {
491 .getKnownMinValue());
493 LLT ScalarTy =
MRI.getType(
MI.getOperand(1).getReg());
500 OpdsMapping[1] = GPRValueMapping;
505 for (
unsigned Idx = 0; Idx < NumOperands; ++Idx) {
506 auto &MO =
MI.getOperand(Idx);
507 if (!MO.isReg() || !MO.getReg())
509 LLT Ty =
MRI.getType(MO.getReg());
519 OpdsMapping[Idx] = GPRValueMapping;