aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs
diff options
context:
space:
mode:
authorgdk <gab.dark.100@gmail.com>2019-10-13 03:02:07 -0300
committerThog <thog@protonmail.com>2020-01-09 02:13:00 +0100
commit1876b346fea647e8284a66bb6d62c38801035cff (patch)
tree6eeff094298cda84d1613dc5ec0691e51d7b35f1 /Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs
parentf617fb542a0e3d36012d77a4b5acbde7b08902f2 (diff)
Initial work
Diffstat (limited to 'Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs')
-rw-r--r--Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs61
1 files changed, 0 insertions, 61 deletions
diff --git a/Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs b/Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs
deleted file mode 100644
index 94975337..00000000
--- a/Ryujinx.Graphics/Shader/IntermediateRepresentation/BasicBlock.cs
+++ /dev/null
@@ -1,61 +0,0 @@
-using System.Collections.Generic;
-
-namespace Ryujinx.Graphics.Shader.IntermediateRepresentation
-{
- class BasicBlock
- {
- public int Index { get; set; }
-
- public LinkedList<INode> Operations { get; }
-
- private BasicBlock _next;
- private BasicBlock _branch;
-
- public BasicBlock Next
- {
- get => _next;
- set => _next = AddSuccessor(_next, value);
- }
-
- public BasicBlock Branch
- {
- get => _branch;
- set => _branch = AddSuccessor(_branch, value);
- }
-
- public bool HasBranch => _branch != null;
-
- public List<BasicBlock> Predecessors { get; }
-
- public HashSet<BasicBlock> DominanceFrontiers { get; }
-
- public BasicBlock ImmediateDominator { get; set; }
-
- public BasicBlock()
- {
- Operations = new LinkedList<INode>();
-
- Predecessors = new List<BasicBlock>();
-
- DominanceFrontiers = new HashSet<BasicBlock>();
- }
-
- public BasicBlock(int index) : this()
- {
- Index = index;
- }
-
- private BasicBlock AddSuccessor(BasicBlock oldBlock, BasicBlock newBlock)
- {
- oldBlock?.Predecessors.Remove(this);
- newBlock?.Predecessors.Add(this);
-
- return newBlock;
- }
-
- public INode GetLastOp()
- {
- return Operations.Last?.Value;
- }
- }
-} \ No newline at end of file