From 33cad9b4543825bb275a936bdfe320e9da804b54 Mon Sep 17 00:00:00 2001 From: Tom French Date: Fri, 10 Jan 2025 12:56:00 +0000 Subject: [PATCH 1/3] chore: disallow inserting ACIR-only instructions into brillig functions --- .../src/brillig/brillig_gen/brillig_block.rs | 2 +- compiler/noirc_evaluator/src/ssa/ir/dfg.rs | 13 ++++++++++++- compiler/noirc_evaluator/src/ssa/ir/instruction.rs | 6 ------ 3 files changed, 13 insertions(+), 8 deletions(-) diff --git a/compiler/noirc_evaluator/src/brillig/brillig_gen/brillig_block.rs b/compiler/noirc_evaluator/src/brillig/brillig_gen/brillig_block.rs index 31c99bf433..0ba180ac0e 100644 --- a/compiler/noirc_evaluator/src/brillig/brillig_gen/brillig_block.rs +++ b/compiler/noirc_evaluator/src/brillig/brillig_gen/brillig_block.rs @@ -795,7 +795,7 @@ impl<'block> BrilligBlock<'block> { self.brillig_context.deallocate_register(rc_register); } Instruction::EnableSideEffectsIf { .. } => { - todo!("enable_side_effects not supported by brillig") + unreachable!("enable_side_effects not supported by brillig") } Instruction::IfElse { .. } => { unreachable!("IfElse instructions should not be possible in brillig") diff --git a/compiler/noirc_evaluator/src/ssa/ir/dfg.rs b/compiler/noirc_evaluator/src/ssa/ir/dfg.rs index 8425e4d5e5..157e0923b0 100644 --- a/compiler/noirc_evaluator/src/ssa/ir/dfg.rs +++ b/compiler/noirc_evaluator/src/ssa/ir/dfg.rs @@ -20,6 +20,7 @@ use iter_extended::vecmap; use serde::{Deserialize, Serialize}; use serde_with::serde_as; use serde_with::DisplayFromStr; +use tracing::warn; /// The DataFlowGraph contains most of the actual data in a function including /// its blocks, instructions, and values. This struct is largely responsible for @@ -181,7 +182,16 @@ impl DataFlowGraph { /// Check if the function runtime would simply ignore this instruction. pub(crate) fn is_handled_by_runtime(&self, instruction: &Instruction) -> bool { - !(self.runtime().is_acir() && instruction.is_brillig_only()) + match self.runtime() { + RuntimeType::Acir(_) => !matches!( + instruction, + Instruction::IncrementRc { .. } | Instruction::DecrementRc { .. } + ), + RuntimeType::Brillig(_) => !matches!( + instruction, + Instruction::EnableSideEffectsIf { .. } | Instruction::IfElse { .. } + ), + } } fn insert_instruction_without_simplification( @@ -228,6 +238,7 @@ impl DataFlowGraph { call_stack: CallStackId, ) -> InsertInstructionResult { if !self.is_handled_by_runtime(&instruction) { + warn!("Attempted to insert instruction not handled by runtime: {instruction:?}"); return InsertInstructionResult::InstructionRemoved; } match instruction.simplify(self, block, ctrl_typevars.clone(), call_stack) { diff --git a/compiler/noirc_evaluator/src/ssa/ir/instruction.rs b/compiler/noirc_evaluator/src/ssa/ir/instruction.rs index 17cde96cdd..9582e1ad23 100644 --- a/compiler/noirc_evaluator/src/ssa/ir/instruction.rs +++ b/compiler/noirc_evaluator/src/ssa/ir/instruction.rs @@ -1058,12 +1058,6 @@ impl Instruction { Instruction::Noop => Remove, } } - - /// Some instructions are only to be used in Brillig and should be eliminated - /// after runtime separation, never to be be reintroduced in an ACIR runtime. - pub(crate) fn is_brillig_only(&self) -> bool { - matches!(self, Instruction::IncrementRc { .. } | Instruction::DecrementRc { .. }) - } } /// Given a chain of operations like: From 2131fcaabfd05e71e9a999c464257ee194ed1fab Mon Sep 17 00:00:00 2001 From: Tom French Date: Fri, 10 Jan 2025 17:14:50 +0000 Subject: [PATCH 2/3] . --- compiler/noirc_evaluator/src/ssa/opt/constant_folding.rs | 2 -- 1 file changed, 2 deletions(-) diff --git a/compiler/noirc_evaluator/src/ssa/opt/constant_folding.rs b/compiler/noirc_evaluator/src/ssa/opt/constant_folding.rs index db249f3bc3..3f503da7f9 100644 --- a/compiler/noirc_evaluator/src/ssa/opt/constant_folding.rs +++ b/compiler/noirc_evaluator/src/ssa/opt/constant_folding.rs @@ -1565,7 +1565,6 @@ mod test { v10 = mul v0, v9 // attaching `c` to `a` v11 = call to_be_radix(v10, u32 256) -> [u8; 1] // calling `to_radix(c * a)` inc_rc v11 - enable_side_effects v2 // side effect var for `c` shifted down by removal return } "; @@ -1580,7 +1579,6 @@ mod test { v7 = mul v0, v6 v8 = call to_be_radix(v7, u32 256) -> [u8; 1] inc_rc v8 - enable_side_effects v2 return } "; From 227af613bd058d55a034ac98af680a7828da3527 Mon Sep 17 00:00:00 2001 From: Tom French Date: Fri, 10 Jan 2025 18:41:27 +0000 Subject: [PATCH 3/3] . --- compiler/noirc_evaluator/src/ssa/ir/dfg.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/compiler/noirc_evaluator/src/ssa/ir/dfg.rs b/compiler/noirc_evaluator/src/ssa/ir/dfg.rs index 6dd8316438..145dc56bcb 100644 --- a/compiler/noirc_evaluator/src/ssa/ir/dfg.rs +++ b/compiler/noirc_evaluator/src/ssa/ir/dfg.rs @@ -215,7 +215,7 @@ impl DataFlowGraph { call_stack: CallStackId, ) -> InsertInstructionResult { if !self.is_handled_by_runtime(&instruction_data) { - return InsertInstructionResult::InstructionRemoved; + panic!("Attempted to insert instruction not handled by runtime: {instruction_data:?}"); } let id = self.insert_instruction_without_simplification(