Skip to content

Commit

Permalink
AArch64: Implement regMaskToRealRegister method
Browse files Browse the repository at this point in the history
This commit implements `OMR::ARM64::RealRegister::regMaskToRealRegister`.
It also removes unnecessary aarch/codegen/RealRegister.hpp.

Signed-off-by: Akira Saitoh <saiaki@jp.ibm.com>
  • Loading branch information
Akira Saitoh committed Sep 7, 2020
1 parent 60ea4a0 commit a6c8e63
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 60 deletions.
17 changes: 17 additions & 0 deletions compiler/aarch64/codegen/OMRRealRegister.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,25 @@
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 OR LicenseRef-GPL-2.0 WITH Assembly-exception
*******************************************************************************/

#include "codegen/CodeGenerator.hpp"
#include "codegen/Machine.hpp"
#include "codegen/RealRegister.hpp"

TR::RealRegister *
OMR::ARM64::RealRegister::regMaskToRealRegister(TR_RegisterMask mask, TR_RegisterKinds rk, TR::CodeGenerator *cg)
{
RegNum rr;

int32_t bitPos = TR::RealRegister::getBitPosInMask(mask);

if (rk == TR_GPR)
rr = FirstGPR;
else if (rk == TR_FPR)
rr = FirstFPR;

return cg->machine()->getRealRegister(RegNum(rr+bitPos));
}

TR_RegisterMask
OMR::ARM64::RealRegister::getAvailableRegistersMask(TR_RegisterKinds rk)
{
Expand Down
9 changes: 9 additions & 0 deletions compiler/aarch64/codegen/OMRRealRegister.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,15 @@ class OMR_EXTENSIBLE RealRegister : public OMR::RealRegister
*/
static TR_RegisterMask getAvailableRegistersMask(TR_RegisterKinds rk);

/**
* @brief Returns real register for the passed register mask
* @param[in] mask : register mask
* @param[in] rk : register kind
* @param[in] cg : code generator
* @returns real register
*/
static TR::RealRegister *regMaskToRealRegister(TR_RegisterMask mask, TR_RegisterKinds rk, TR::CodeGenerator *cg);

private:

static const uint8_t fullRegBinaryEncodings[NumRegisters];
Expand Down
60 changes: 0 additions & 60 deletions compiler/aarch64/codegen/RealRegister.hpp

This file was deleted.

0 comments on commit a6c8e63

Please sign in to comment.