mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	[obcjarcopts] Encapsulate PtrState.RRI.KnownSafe in the methods PtrState.IsKnownSafe and PtrState.SetKnownSafe.
This is apart of a series of patches to encapsulate PtrState.RRI and make PtrState.RRI a private field of PtrState. *NOTE* This is actually the second commit in the patch stream. I should have put this note on the first such commit r184528. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184532 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -530,6 +530,15 @@ namespace { | ||||
|     PtrState() : KnownPositiveRefCount(false), Partial(false), | ||||
|                  Seq(S_None) {} | ||||
|  | ||||
|  | ||||
|     bool IsKnownSafe() const { | ||||
|       return RRI.KnownSafe;     | ||||
|     } | ||||
|  | ||||
|     void SetKnownSafe(const bool NewValue) { | ||||
|       RRI.KnownSafe = NewValue; | ||||
|     } | ||||
|  | ||||
|     void SetKnownPositiveRefCount() { | ||||
|       DEBUG(dbgs() << "Setting Known Positive.\n"); | ||||
|       KnownPositiveRefCount = true; | ||||
| @@ -1723,7 +1732,7 @@ static void CheckForUseCFGHazard(const Sequence SuccSSeq, | ||||
|                                  bool &ShouldContinue) { | ||||
|   switch (SuccSSeq) { | ||||
|   case S_CanRelease: { | ||||
|     if (!S.RRI.KnownSafe && !SuccSRRIKnownSafe) { | ||||
|     if (!S.IsKnownSafe() && !SuccSRRIKnownSafe) { | ||||
|       S.ClearSequenceProgress(); | ||||
|       break; | ||||
|     } | ||||
| @@ -1737,7 +1746,7 @@ static void CheckForUseCFGHazard(const Sequence SuccSSeq, | ||||
|   case S_Stop: | ||||
|   case S_Release: | ||||
|   case S_MovableRelease: | ||||
|     if (!S.RRI.KnownSafe && !SuccSRRIKnownSafe) | ||||
|     if (!S.IsKnownSafe() && !SuccSRRIKnownSafe) | ||||
|       AllSuccsHaveSame = false; | ||||
|     else | ||||
|       NotAllSeqEqualButKnownSafe = true; | ||||
| @@ -1766,7 +1775,7 @@ static void CheckForCanReleaseCFGHazard(const Sequence SuccSSeq, | ||||
|   case S_Release: | ||||
|   case S_MovableRelease: | ||||
|   case S_Use: | ||||
|     if (!S.RRI.KnownSafe && !SuccSRRIKnownSafe) | ||||
|     if (!S.IsKnownSafe() && !SuccSRRIKnownSafe) | ||||
|       AllSuccsHaveSame = false; | ||||
|     else | ||||
|       NotAllSeqEqualButKnownSafe = true; | ||||
| @@ -1830,7 +1839,7 @@ ObjCARCOpt::CheckForCFGHazards(const BasicBlock *BB, | ||||
|  | ||||
|       // If we have S_Use or S_CanRelease, perform our check for cfg hazard | ||||
|       // checks. | ||||
|       const bool SuccSRRIKnownSafe = SuccS.RRI.KnownSafe; | ||||
|       const bool SuccSRRIKnownSafe = SuccS.IsKnownSafe(); | ||||
|  | ||||
|       // *NOTE* We do not use Seq from above here since we are allowing for | ||||
|       // S.GetSeq() to change while we are visiting basic blocks. | ||||
| @@ -1908,7 +1917,7 @@ ObjCARCOpt::VisitInstructionBottomUp(Instruction *Inst, | ||||
|     ANNOTATE_BOTTOMUP(Inst, Arg, S.GetSeq(), NewSeq); | ||||
|     S.ResetSequenceProgress(NewSeq); | ||||
|     S.RRI.ReleaseMetadata = ReleaseMetadata; | ||||
|     S.RRI.KnownSafe = S.HasKnownPositiveRefCount(); | ||||
|     S.SetKnownSafe(S.HasKnownPositiveRefCount()); | ||||
|     S.RRI.IsTailCallRelease = cast<CallInst>(Inst)->isTailCall(); | ||||
|     S.RRI.Calls.insert(Inst); | ||||
|     S.SetKnownPositiveRefCount(); | ||||
| @@ -2166,7 +2175,7 @@ ObjCARCOpt::VisitInstructionTopDown(Instruction *Inst, | ||||
|  | ||||
|       ANNOTATE_TOPDOWN(Inst, Arg, S.GetSeq(), S_Retain); | ||||
|       S.ResetSequenceProgress(S_Retain); | ||||
|       S.RRI.KnownSafe = S.HasKnownPositiveRefCount(); | ||||
|       S.SetKnownSafe(S.HasKnownPositiveRefCount()); | ||||
|       S.RRI.Calls.insert(Inst); | ||||
|     } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user