Skip to content

Commit

Permalink
Merge pull request #7124 from dylanjtuttle/aixSwitchCases
Browse files Browse the repository at this point in the history
Add default cases to PPC switch statements
  • Loading branch information
hzongaro authored Oct 12, 2023
2 parents 2a7cf70 + 0e76447 commit 2843bc5
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 18 deletions.
2 changes: 2 additions & 0 deletions compiler/p/codegen/OMRCodeGenerator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2436,6 +2436,8 @@ OMR::Power::CodeGenerator::supportsNonHelper(TR::SymbolReferenceTable::CommonNon
result = self()->comp()->target().is64Bit();
break;
}
default:
break;
}

return result;
Expand Down
51 changes: 33 additions & 18 deletions compiler/p/codegen/OMRMachine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -90,8 +90,9 @@ static int32_t spillSizeForRegister(TR::Register *virtReg)
case TR_VSX_VECTOR:
case TR_VRF:
return 16;
default:
TR_ASSERT(false, "Unexpected register kind");
}
TR_ASSERT(false, "Unexpected register kind");
return 0;
}

Expand Down Expand Up @@ -252,6 +253,8 @@ TR::RealRegister *OMR::Power::Machine::findBestFreeRegister(TR::Instruction *cur
case TR_VRF:
maskI = TR::RealRegister::FirstVRF;
break;
default:
break;
}

if (liveRegOn && preference!=0 && (interference & (1<<(preference-maskI))))
Expand Down Expand Up @@ -493,6 +496,8 @@ TR::RealRegister *OMR::Power::Machine::freeBestRegister(TR::Instruction *cur
maskI = first = TR::RealRegister::FirstVRF;
last = TR::RealRegister::LastVRF;
break;
default:
break;
}

int32_t preference = 0, pref_favored = 0;
Expand Down Expand Up @@ -724,6 +729,8 @@ TR::RealRegister *OMR::Power::Machine::freeBestRegister(TR::Instruction *cur
location = self()->cg()->allocateSpill(16, false, NULL);
}
break;
default:
break;
}

if (rk == TR_CCR)
Expand Down Expand Up @@ -844,6 +851,8 @@ TR::RealRegister *OMR::Power::Machine::freeBestRegister(TR::Instruction *cur
reloadInstr = generateTrg1MemInstruction(self()->cg(), opCode, currentNode, best, tmemref, currentInstruction);
self()->cg()->stopUsingRegister(tempIndexRegister);
break;
default:
break;
}

self()->cg()->traceRegFreed(candidates[0], best);
Expand Down Expand Up @@ -1081,6 +1090,8 @@ TR::RealRegister *OMR::Power::Machine::reverseSpillState(TR::Instruction *c
spillInstr = generateMemSrc1Instruction(self()->cg(), opCode, currentNode, tmemref, targetRegister, currentInstruction);
self()->cg()->stopUsingRegister(tempIndexRegister);
break;
default:
break;
}
self()->cg()->traceRAInstruction(spillInstr);
if (rk == TR_CCR)
Expand Down Expand Up @@ -1755,6 +1766,8 @@ static void registerCopy(TR::Instruction *precedingInstruction,
case TR_VRF:
instr = generateTrg1Src2Instruction(cg, TR::InstOpCode::vor, currentNode, targetReg, sourceReg, sourceReg, precedingInstruction);
break;
default:
break;
}
cg->traceRAInstruction(instr);
}
Expand All @@ -1779,23 +1792,25 @@ static void registerExchange(TR::Instruction *precedingInstruction,
{
TR::InstOpCode::Mnemonic opCode;
switch (rk)
{
case TR_GPR:
opCode = TR::InstOpCode::XOR;
break;
case TR_FPR:
opCode = TR::InstOpCode::xxlxor;
break;
case TR_VSX_SCALAR:
case TR_VSX_VECTOR:
opCode = TR::InstOpCode::xxlxor;
break;
case TR_VRF:
opCode = TR::InstOpCode::vxor;
break;
case TR_CCR:
TR_ASSERT(0, "Cannot exchange CCR without a third reg");
}
{
case TR_GPR:
opCode = TR::InstOpCode::XOR;
break;
case TR_FPR:
opCode = TR::InstOpCode::xxlxor;
break;
case TR_VSX_SCALAR:
case TR_VSX_VECTOR:
opCode = TR::InstOpCode::xxlxor;
break;
case TR_VRF:
opCode = TR::InstOpCode::vxor;
break;
case TR_CCR:
TR_ASSERT(0, "Cannot exchange CCR without a third reg");
default:
break;
}
cg->traceRAInstruction(generateTrg1Src2Instruction(cg, opCode, currentNode, targetReg, targetReg, sourceReg, precedingInstruction));
cg->traceRAInstruction(generateTrg1Src2Instruction(cg, opCode, currentNode, sourceReg, targetReg, sourceReg, precedingInstruction));
cg->traceRAInstruction(generateTrg1Src2Instruction(cg, opCode, currentNode, targetReg, targetReg, sourceReg, precedingInstruction));
Expand Down
2 changes: 2 additions & 0 deletions compiler/p/codegen/OMRPeephole.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -702,6 +702,8 @@ OMR::Power::Peephole::tryToRemoveRedundantMoveRegister()
}
break;
}
default:
break;
}
}

Expand Down
2 changes: 2 additions & 0 deletions compiler/p/codegen/OMRRegisterDependency.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1088,6 +1088,8 @@ void OMR::Power::RegisterDependencyGroup::assignRegisters(TR::Instruction *cur
case TR_VRF:
depsBlocked = haveSpareVRFs;
break;
default:
break;
}
assignContendedRegisters(currentInstruction, &_dependencies[i], map, depsBlocked, cg);
}
Expand Down
2 changes: 2 additions & 0 deletions compiler/p/codegen/PPCDebug.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -290,6 +290,8 @@ TR_Debug::print(TR::FILE *pOutFile, TR::PPCLabelInstruction * instr)
case TR::Snippet::IsArrayCopyCall:
callSym = ((TR::PPCHelperCallSnippet *)snippet)->getDestination();
break;
default:
break;
}
if (callSym)
trfprintf(pOutFile, "\t; Call \"%s\"", getName(callSym));
Expand Down

0 comments on commit 2843bc5

Please sign in to comment.