| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- using Ryujinx.Graphics.Shader.IntermediateRepresentation;
- using Ryujinx.Graphics.Shader.Translation;
- using System.Numerics;
- using static Ryujinx.Graphics.Shader.StructuredIr.AstHelper;
- namespace Ryujinx.Graphics.Shader.StructuredIr
- {
- class AstOperation : AstNode
- {
- public Instruction Inst { get; }
- public StorageKind StorageKind { get; }
- public int Index { get; }
- private IAstNode[] _sources;
- public int SourcesCount => _sources.Length;
- public AstOperation(Instruction inst, StorageKind storageKind, IAstNode[] sources, int sourcesCount)
- {
- Inst = inst;
- StorageKind = storageKind;
- _sources = sources;
- for (int index = 0; index < sources.Length; index++)
- {
- if (index < sourcesCount)
- {
- AddUse(sources[index], this);
- }
- else
- {
- AddDef(sources[index], this);
- }
- }
- Index = 0;
- }
- public AstOperation(Instruction inst, StorageKind storageKind, int index, IAstNode[] sources, int sourcesCount) : this(inst, storageKind, sources, sourcesCount)
- {
- Index = index;
- }
- public AstOperation(Instruction inst, params IAstNode[] sources) : this(inst, StorageKind.None, sources, sources.Length)
- {
- }
- public IAstNode GetSource(int index)
- {
- return _sources[index];
- }
- public void SetSource(int index, IAstNode source)
- {
- RemoveUse(_sources[index], this);
- AddUse(source, this);
- _sources[index] = source;
- }
- public AggregateType GetVectorType(AggregateType scalarType)
- {
- int componentsCount = BitOperations.PopCount((uint)Index);
- AggregateType type = scalarType;
- switch (componentsCount)
- {
- case 2: type |= AggregateType.Vector2; break;
- case 3: type |= AggregateType.Vector3; break;
- case 4: type |= AggregateType.Vector4; break;
- }
- return type;
- }
- }
- }
|