当前位置: 首页>>代码示例>>C#>>正文


C# Context.SetBranch方法代码示例

本文整理汇总了C#中Mosa.Runtime.CompilerFramework.Context.SetBranch方法的典型用法代码示例。如果您正苦于以下问题:C# Context.SetBranch方法的具体用法?C# Context.SetBranch怎么用?C# Context.SetBranch使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Mosa.Runtime.CompilerFramework.Context的用法示例。


在下文中一共展示了Context.SetBranch方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Run

        /// <summary>
        /// Performs stage specific processing on the compiler context.
        /// </summary>
        public void Run()
        {
            // Create the prologue block
            Context ctx = new Context(InstructionSet, -1);
            // Add a jump instruction to the first block from the prologue
            ctx.AppendInstruction(IR.Instruction.JmpInstruction);
            //ctx.AppendInstruction(CIL.Instruction.Get(CIL.OpCode.Br));
            ctx.SetBranch(0);
            ctx.Label = -1;
            _prologue = CreateBlock(-1, ctx.Index);

            SplitIntoBlocks(0);

            // Create the epilogue block
            ctx = new Context(InstructionSet, -1);
            // Add null instruction, necessary to generate a block index
            ctx.AppendInstruction(null);
            ctx.Ignore = true;
            ctx.Label = Int32.MaxValue;
            _epilogue = CreateBlock(Int32.MaxValue, ctx.Index);

            // Link all the blocks together
            BuildBlockLinks(_prologue);

            // Link Exception Header Clauses
            LinkExceptionHeaderClauses();
        }
开发者ID:davidleon,项目名称:MOSA-Project,代码行数:30,代码来源:BasicBlockBuilderStage.cs

示例2: ConstantOperand

        /// <summary>
        /// Visitation function for <see cref="CIL.ICILVisitor.UnaryBranch"/>.
        /// </summary>
        /// <param name="ctx">The context.</param>
        void CIL.ICILVisitor.UnaryBranch(Context ctx)
        {
            IBranch branch = ctx.Branch;
            CIL.OpCode opcode = (ctx.Instruction as CIL.ICILInstruction).OpCode;
            Operand op = ctx.Operand1;

            ctx.SetInstruction(CPUx86.Instruction.CmpInstruction, ctx.Operand1, new ConstantOperand(new SigType(CilElementType.I4), 0));

            if (opcode == CIL.OpCode.Brtrue || opcode == CIL.OpCode.Brtrue_s)
                ctx.AppendInstruction(CPUx86.Instruction.BranchInstruction, IR.ConditionCode.NotEqual);
            else
                if (opcode == CIL.OpCode.Brfalse || opcode == CIL.OpCode.Brfalse_s)
                    ctx.AppendInstruction(CPUx86.Instruction.BranchInstruction, IR.ConditionCode.Equal);
                else
                    throw new NotImplementedException();

            ctx.SetBranch(branch.Targets[0]);
        }
开发者ID:shanebrown99,项目名称:MOSA-Project,代码行数:22,代码来源:CILTransformationStage.cs

示例3: ConvertCondition

        /// <summary>
        /// Visitation function for <see cref="CIL.ICILVisitor.BinaryBranch"/>.
        /// </summary>
        /// <param name="ctx">The context.</param>
        void CIL.ICILVisitor.BinaryBranch(Context ctx)
        {
            bool swap = ctx.Operand1 is ConstantOperand;
            IBranch branch = ctx.Branch;
            IR.ConditionCode conditionCode = ConvertCondition((ctx.Instruction as CIL.BinaryBranchInstruction).OpCode);

            if (swap) {
                ctx.SetInstruction(CPUx86.Instruction.CmpInstruction, ctx.Operand2, ctx.Operand1);
                ctx.AppendInstruction(CPUx86.Instruction.BranchInstruction, GetOppositeConditionCode(conditionCode));
            }
            else {
                ctx.SetInstruction(CPUx86.Instruction.CmpInstruction, ctx.Operand1, ctx.Operand2);
                ctx.AppendInstruction(CPUx86.Instruction.BranchInstruction, conditionCode);
            }

            ctx.SetBranch(branch.Targets[0]);
        }
开发者ID:shanebrown99,项目名称:MOSA-Project,代码行数:21,代码来源:CILTransformationStage.cs

示例4:

        /// <summary>
        /// Visitation function for <see cref="IR.IIRVisitor.ReturnInstruction"/> instruction.
        /// </summary>
        /// <param name="ctx">The context.</param>
        void IR.IIRVisitor.ReturnInstruction(Context ctx)
        {
            Operand op = ctx.Operand1;

            if (op != null)
            {
                ICallingConvention cc = Architecture.GetCallingConvention (MethodCompiler.Method.Signature.CallingConvention);
                cc.MoveReturnValue (ctx, op);
                ctx.AppendInstruction (CPUx86.Instruction.JmpInstruction);
                ctx.SetBranch (Int32.MaxValue);
            }

            else
            {
                ctx.SetInstruction (CPUx86.Instruction.JmpInstruction);
                ctx.SetBranch (Int32.MaxValue);
            }
        }
开发者ID:hj1980,项目名称:Mosa,代码行数:22,代码来源:IRTransformationStage.cs

示例5:

        /// <summary>
        /// Visitation function for ReturnInstruction.
        /// </summary>
        /// <param name="context">The context.</param>
        void IR.IIRVisitor.ReturnInstruction(Context context)
        {
            Operand op = context.Operand1;

            if (op != null)
            {
                callingConvention.MoveReturnValue(context, op);
                context.AppendInstruction(CPUx86.Instruction.JmpInstruction);
                context.SetBranch(Int32.MaxValue);
            }
            else
            {
                context.SetInstruction(CPUx86.Instruction.JmpInstruction);
                context.SetBranch(Int32.MaxValue);
            }
        }
开发者ID:davidleon,项目名称:MOSA-Project,代码行数:20,代码来源:IRTransformationStage.cs

示例6: switch

        /// <summary>
        /// Visitation function for <see cref="CIL.ICILVisitor.BinaryBranch"/>.
        /// </summary>
        /// <param name="ctx">The context.</param>
        void CIL.ICILVisitor.BinaryBranch(Context ctx)
        {
            bool swap = ctx.Operand1 is ConstantOperand;
            IBranch branch = ctx.Branch;
            CIL.OpCode opcode = (ctx.Instruction as CIL.BinaryBranchInstruction).OpCode;
            IR.ConditionCode conditionCode;

            if (swap)
            {
                int tmp = branch.Targets[0];
                branch.Targets[0] = branch.Targets[1];
                branch.Targets[1] = tmp;

                ctx.SetInstruction (CPUx86.Instruction.CmpInstruction, ctx.Operand2, ctx.Operand1);

                switch (opcode) {
                // Signed
                case CIL.OpCode.Beq_s:
                    conditionCode = IR.ConditionCode.NotEqual;
                    break;
                case CIL.OpCode.Bge_s:
                    conditionCode = IR.ConditionCode.LessThan;
                    break;
                case CIL.OpCode.Bgt_s:
                    conditionCode = IR.ConditionCode.LessOrEqual;
                    break;
                case CIL.OpCode.Ble_s:
                    conditionCode = IR.ConditionCode.GreaterThan;
                    break;
                case CIL.OpCode.Blt_s:
                    conditionCode = IR.ConditionCode.GreaterOrEqual;
                    break;

                // Unsigned
                case CIL.OpCode.Bne_un_s:
                    conditionCode = IR.ConditionCode.Equal;
                    break;
                case CIL.OpCode.Bge_un_s:
                    conditionCode = IR.ConditionCode.UnsignedLessThan;
                    break;
                case CIL.OpCode.Bgt_un_s:
                    conditionCode = IR.ConditionCode.UnsignedLessOrEqual;
                    break;
                case CIL.OpCode.Ble_un_s:
                    conditionCode = IR.ConditionCode.UnsignedGreaterThan;
                    break;
                case CIL.OpCode.Blt_un_s:
                    conditionCode = IR.ConditionCode.UnsignedGreaterOrEqual;
                    break;

                // Long form signed
                case CIL.OpCode.Beq:
                    goto case CIL.OpCode.Beq_s;
                case CIL.OpCode.Bge:
                    goto case CIL.OpCode.Bge_s;
                case CIL.OpCode.Bgt:
                    goto case CIL.OpCode.Bgt_s;
                case CIL.OpCode.Ble:
                    goto case CIL.OpCode.Ble_s;
                case CIL.OpCode.Blt:
                    goto case CIL.OpCode.Blt_s;

                // Long form unsigned
                case CIL.OpCode.Bne_un:
                    goto case CIL.OpCode.Bne_un_s;
                case CIL.OpCode.Bge_un:
                    goto case CIL.OpCode.Bge_un_s;
                case CIL.OpCode.Bgt_un:
                    goto case CIL.OpCode.Bgt_un_s;
                case CIL.OpCode.Ble_un:
                    goto case CIL.OpCode.Ble_un_s;
                case CIL.OpCode.Blt_un:
                    goto case CIL.OpCode.Blt_un_s;
                default:

                    throw new NotImplementedException ();
                }
                ctx.AppendInstruction (CPUx86.Instruction.BranchInstruction, conditionCode);
                ctx.SetBranch (branch.Targets[0]);
            }

            else
            {
                ctx.SetInstruction (CPUx86.Instruction.CmpInstruction, ctx.Operand1, ctx.Operand2);

                switch (opcode) {
                // Signed
                case CIL.OpCode.Beq_s:
                    conditionCode = IR.ConditionCode.Equal;
                    break;
                case CIL.OpCode.Bge_s:
                    conditionCode = IR.ConditionCode.GreaterOrEqual;
                    break;
                case CIL.OpCode.Bgt_s:
                    conditionCode = IR.ConditionCode.GreaterThan;
                    break;
//.........这里部分代码省略.........
开发者ID:54616E6E6572,项目名称:Mosa,代码行数:101,代码来源:CILTransformationStage.cs

示例7: BinaryBranch

        /// <summary>
        /// Visitation function for <see cref="ICILVisitor.BinaryBranch"/>.
        /// </summary>
        /// <param name="ctx">The context.</param>
        public void BinaryBranch(Context ctx)
        {
            IBranch branch = ctx.Branch;

            ConditionCode cc = ConvertCondition(((ICILInstruction)ctx.Instruction).OpCode);
            Operand first = ctx.Operand1;
            Operand second = ctx.Operand2;

            IInstruction comparisonInstruction = Instruction.IntegerCompareInstruction;
            if (first.StackType == StackTypeCode.F)
            {
                comparisonInstruction = Instruction.FloatingPointCompareInstruction;
            }

            Operand comparisonResult = this.MethodCompiler.CreateTemporary(BuiltInSigType.Int32);
            ctx.SetInstruction(comparisonInstruction, comparisonResult, first, second);
            ctx.ConditionCode = cc;

            ctx.AppendInstruction(Instruction.BranchInstruction, comparisonResult);
            ctx.ConditionCode = cc;
            ctx.SetBranch(branch.Targets[0]);
        }
开发者ID:davidbjornn,项目名称:MOSA-Project,代码行数:26,代码来源:CILTransformationStage.cs

示例8: UnaryBranch

        /// <summary>
        /// Visitation function for <see cref="ICILVisitor.UnaryBranch"/>.
        /// </summary>
        /// <param name="ctx">The context.</param>
        public void UnaryBranch(Context ctx)
        {
            IBranch branch = ctx.Branch;

            ConditionCode cc;
            Operand first = ctx.Operand1;
            Operand second = new ConstantOperand(BuiltInSigType.Int32, 0UL);

            OpCode opcode = ((ICILInstruction)ctx.Instruction).OpCode;
            if (opcode == OpCode.Brtrue || opcode == OpCode.Brtrue_s)
            {
                cc = ConditionCode.NotEqual;
            }
            else if (opcode == OpCode.Brfalse || opcode == OpCode.Brfalse_s)
            {
                cc = ConditionCode.Equal;
            }
            else
            {
                throw new NotSupportedException(@"CILTransformationStage.UnaryBranch doesn't support CIL opcode " + opcode);
            }

            Operand comparisonResult = this.MethodCompiler.CreateTemporary(BuiltInSigType.Int32);
            ctx.SetInstruction(Instruction.IntegerCompareInstruction, comparisonResult, first, second);
            ctx.ConditionCode = cc;

            ctx.AppendInstruction(Instruction.BranchInstruction, comparisonResult);
            ctx.ConditionCode = cc;
            ctx.SetBranch(branch.Targets[0]);
        }
开发者ID:davidbjornn,项目名称:MOSA-Project,代码行数:34,代码来源:CILTransformationStage.cs

示例9: BinaryBranch

        /// <summary>
        /// Visitation function for BinaryBranch instruction.
        /// </summary>
        /// <param name="context">The context.</param>
        public void BinaryBranch(Context context)
        {
            IBranch branch = context.Branch;

            ConditionCode cc = ConvertCondition(((CIL.ICILInstruction)context.Instruction).OpCode);
            Operand first = context.Operand1;
            Operand second = context.Operand2;

            IInstruction comparisonInstruction = Instruction.IntegerCompareInstruction;
            if (first.StackType == StackTypeCode.F)
            {
                comparisonInstruction = Instruction.FloatingPointCompareInstruction;
                Operand comparisonResult = this.methodCompiler.CreateTemporary(BuiltInSigType.Int32);
                context.SetInstruction(comparisonInstruction, comparisonResult, first, second);
                context.ConditionCode = cc;

                context.AppendInstruction(Instruction.IntegerCompareInstruction, comparisonResult, comparisonResult, new ConstantOperand(new SigType(CilElementType.I), 1));
                context.ConditionCode = ConditionCode.Equal;
                context.AppendInstruction(Instruction.BranchInstruction, comparisonResult);
                context.ConditionCode = ConditionCode.Equal;
                context.SetBranch(branch.Targets[0]);
                context.AppendInstruction(Instruction.JmpInstruction);
                context.SetBranch(context.Next.Label);
            }
            else
            {
                Operand comparisonResult = this.methodCompiler.CreateTemporary(BuiltInSigType.Int32);
                context.SetInstruction(comparisonInstruction, comparisonResult, first, second);
                context.ConditionCode = cc;

                context.AppendInstruction(Instruction.BranchInstruction, comparisonResult);
                context.ConditionCode = cc;
                context.SetBranch(branch.Targets[0]);
            }
        }
开发者ID:davidleon,项目名称:MOSA-Project,代码行数:39,代码来源:CILTransformationStage.cs

示例10: SwitchInstruction

        public void SwitchInstruction(Context context)
        {
            IBranch branch = context.Branch;
            Operand operand = context.Operand1;

            context.Remove();

            for (int i = 0; i < branch.Targets.Length - 1; ++i)
            {
                context.AppendInstruction(CPUx86.Instruction.CmpInstruction, operand, new ConstantOperand(new SigType(CilElementType.I), i));
                context.AppendInstruction(CPUx86.Instruction.BranchInstruction, IR.ConditionCode.Equal);
                context.SetBranch(branch.Targets[i]);
            }
        }
开发者ID:davidbjornn,项目名称:MOSA-Project,代码行数:14,代码来源:IRTransformationStage.cs

示例11: ReturnInstruction

        /// <summary>
        /// Visitation function for <see cref="IR.IIRVisitor.ReturnInstruction"/> instruction.
        /// </summary>
        /// <param name="ctx">The context.</param>
        public void ReturnInstruction(Context ctx)
        {
            Operand op = ctx.Operand1;

            if (op != null) {
                ICallingConvention cc = Architecture.GetCallingConvention();
                cc.MoveReturnValue(ctx, op);
                ctx.AppendInstruction(CPUx86.Instruction.JmpInstruction);
                ctx.SetBranch(Int32.MaxValue);
            }
            else {
                ctx.SetInstruction(CPUx86.Instruction.JmpInstruction);
                ctx.SetBranch(Int32.MaxValue);
            }
        }
开发者ID:davidbjornn,项目名称:MOSA-Project,代码行数:19,代码来源:IRTransformationStage.cs


注:本文中的Mosa.Runtime.CompilerFramework.Context.SetBranch方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。