[Project64] Add ArmBreakPoint

This commit is contained in:
zilmar 2016-11-22 18:09:37 +11:00
parent 28e4ba2e8c
commit e5b260b078
2 changed files with 19 additions and 2 deletions

View File

@ -226,6 +226,15 @@ void CArmOps::AndArmRegToArmReg(ArmReg DestReg, ArmReg SourceReg1, ArmReg Source
} }
} }
void CArmOps::ArmBreakPoint(const char * FileName, uint32_t LineNumber)
{
m_RegWorkingSet.BeforeCallDirect();
MoveConstToArmReg(Arm_R1, LineNumber);
MoveConstToArmReg(Arm_R0, (uint32_t)FileName, FileName);
CallFunction(AddressOf(&BreakPointNotification), "BreakPointNotification");
m_RegWorkingSet.AfterCallDirect();
}
void CArmOps::BranchLabel8(ArmCompareType CompareType, const char * Label) void CArmOps::BranchLabel8(ArmCompareType CompareType, const char * Label)
{ {
if (mInItBlock) { g_Notify->BreakPoint(__FILE__,__LINE__); } if (mInItBlock) { g_Notify->BreakPoint(__FILE__,__LINE__); }
@ -1409,6 +1418,11 @@ void * CArmOps::GetAddressOf(int value, ...)
return Address; return Address;
} }
void CArmOps::BreakPointNotification(const char * FileName, uint32_t LineNumber)
{
g_Notify->BreakPoint(FileName, LineNumber);
}
bool CArmOps::ArmCompareInverse (ArmCompareType CompareType) bool CArmOps::ArmCompareInverse (ArmCompareType CompareType)
{ {
switch (CompareType) switch (CompareType)
@ -1432,7 +1446,7 @@ const char * CArmOps::ArmCompareSuffix(ArmCompareType CompareType)
case ArmBranch_Equal: return "eq"; case ArmBranch_Equal: return "eq";
case ArmBranch_Notequal: return "ne"; case ArmBranch_Notequal: return "ne";
case ArmBranch_GreaterThanOrEqual: return "ge"; case ArmBranch_GreaterThanOrEqual: return "ge";
case ArmBranch_LessThan: return "l"; case ArmBranch_LessThan: return "lt";
case ArmBranch_GreaterThan: return "g"; case ArmBranch_GreaterThan: return "g";
case ArmBranch_LessThanOrEqual: return "le"; case ArmBranch_LessThanOrEqual: return "le";
case ArmBranch_Always: return ""; case ArmBranch_Always: return "";
@ -1457,7 +1471,7 @@ const char * CArmOps::ArmRegName(ArmReg Reg)
case Arm_R8: return "r8"; case Arm_R8: return "r8";
case Arm_R9: return "r9"; case Arm_R9: return "r9";
case Arm_R10: return "r10"; case Arm_R10: return "r10";
case Arm_R11: return "fp"; case Arm_R11: return "r11";
case Arm_R12: return "ip"; case Arm_R12: return "ip";
case ArmRegSP: return "sp"; case ArmRegSP: return "sp";
case ArmRegLR: return "lr"; case ArmRegLR: return "lr";

View File

@ -162,6 +162,7 @@ protected:
static void AndConstToVariable(void *Variable, const char * VariableName, uint32_t Const); static void AndConstToVariable(void *Variable, const char * VariableName, uint32_t Const);
static void AndConstToArmReg(ArmReg DestReg, ArmReg SourceReg, uint32_t Const); static void AndConstToArmReg(ArmReg DestReg, ArmReg SourceReg, uint32_t Const);
static void AndArmRegToArmReg(ArmReg DestReg, ArmReg SourceReg1, ArmReg SourceReg2); static void AndArmRegToArmReg(ArmReg DestReg, ArmReg SourceReg1, ArmReg SourceReg2);
static void ArmBreakPoint(const char * FileName, uint32_t LineNumber);
static void BranchLabel8(ArmCompareType CompareType, const char * Label); static void BranchLabel8(ArmCompareType CompareType, const char * Label);
static void BranchLabel20(ArmCompareType CompareType, const char * Label); static void BranchLabel20(ArmCompareType CompareType, const char * Label);
static void CallFunction(void * Function, const char * FunctionName); static void CallFunction(void * Function, const char * FunctionName);
@ -213,6 +214,8 @@ protected:
protected: protected:
static const char * ArmRegName(ArmReg Reg); static const char * ArmRegName(ArmReg Reg);
static void BreakPointNotification(const char * FileName, uint32_t LineNumber);
static bool ArmCompareInverse(ArmCompareType CompareType); static bool ArmCompareInverse(ArmCompareType CompareType);
static const char * ArmCompareSuffix(ArmCompareType CompareType); static const char * ArmCompareSuffix(ArmCompareType CompareType);
static const char * ArmFpuSingleName(ArmFpuSingle Reg); static const char * ArmFpuSingleName(ArmFpuSingle Reg);