Skip to content

Commit

Permalink
feat: automatic early return when writing strategy is set (#47)
Browse files Browse the repository at this point in the history
  • Loading branch information
nathanielsimard authored Jul 31, 2024
1 parent a20ac61 commit dd274b6
Show file tree
Hide file tree
Showing 6 changed files with 60 additions and 2 deletions.
6 changes: 4 additions & 2 deletions crates/cubecl-core/src/ir/procedure/base.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
use super::{
CheckedIndex, CheckedIndexAssign, ConditionalAssign, IndexOffsetGlobalWithLayout, ReadGlobal,
ReadGlobalWithLayout, WriteGlobal,
CheckedIndex, CheckedIndexAssign, ConditionalAssign, EarlyReturn, IndexOffsetGlobalWithLayout,
ReadGlobal, ReadGlobalWithLayout, WriteGlobal,
};
use crate::ir::Vectorization;
use serde::{Deserialize, Serialize};
Expand All @@ -17,6 +17,7 @@ pub enum Procedure {
CheckedIndex(CheckedIndex),
CheckedIndexAssign(CheckedIndexAssign),
ConditionalAssign(ConditionalAssign),
EarlyReturn(EarlyReturn),
}

impl Procedure {
Expand All @@ -37,6 +38,7 @@ impl Procedure {
Procedure::ConditionalAssign(proc) => {
Procedure::ConditionalAssign(proc.vectorize(vectorization))
}
Procedure::EarlyReturn(proc) => Procedure::EarlyReturn(proc.vectorize(vectorization)),
}
}
}
35 changes: 35 additions & 0 deletions crates/cubecl-core/src/ir/procedure/early_return.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
use crate::ir::{macros::cpa, Branch, Elem, Item, Scope, Variable, Vectorization};
use serde::{Deserialize, Serialize};

/// Perform a check bound on the index (lhs) of value (rhs)
#[derive(Debug, Clone, Serialize, Deserialize, PartialEq)]
#[allow(missing_docs)]
pub struct EarlyReturn {
pub global: Variable,
pub position: Variable,
}

impl EarlyReturn {
#[allow(missing_docs)]
pub fn expand(self, scope: &mut Scope) {
let variable = self.global;
let index = self.position;

let array_len = scope.create_local(Item::new(Elem::UInt));
let outside_bound = scope.create_local(Item::new(Elem::Bool));

cpa!(scope, array_len = len(variable));
cpa!(scope, outside_bound = index >= array_len);

cpa!(scope, if(outside_bound).then(|scope| {
scope.register(Branch::Return);
}));
}

pub(crate) fn vectorize(&self, vectorization: Vectorization) -> Self {
Self {
global: self.global.vectorize(vectorization),
position: self.position.vectorize(vectorization),
}
}
}
2 changes: 2 additions & 0 deletions crates/cubecl-core/src/ir/procedure/mod.rs
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
mod assign;
mod base;
mod early_return;
mod index;
mod read;
mod write;

pub use assign::*;
pub use base::*;
pub use early_return::*;
pub use index::*;
pub use read::*;
pub use write::*;
11 changes: 11 additions & 0 deletions crates/cubecl-core/src/ir/scope.rs
Original file line number Diff line number Diff line change
Expand Up @@ -315,6 +315,17 @@ impl Scope {

let mut operations = Vec::new();

if let Some((_input, global, position)) = self.writes_global.first() {
if self.depth == 0 {
operations.push(Operation::Procedure(Procedure::EarlyReturn(
super::EarlyReturn {
global: *global,
position: *position,
},
)))
}
}

for (input, strategy, local, position) in self.reads_global.drain(..) {
match strategy {
ReadingStrategy::OutputLayout => {
Expand Down
4 changes: 4 additions & 0 deletions crates/cubecl-cuda/src/compiler/base.rs
Original file line number Diff line number Diff line change
Expand Up @@ -314,6 +314,10 @@ impl CudaCompiler {
proc.expand(scope);
compile(scope);
}
gpu::Procedure::EarlyReturn(proc) => {
proc.expand(scope);
compile(scope);
}
}
}

Expand Down
4 changes: 4 additions & 0 deletions crates/cubecl-wgpu/src/compiler/wgsl/compiler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -434,6 +434,10 @@ impl WgslCompiler {
proc.expand(scope);
compile(scope);
}
cube::Procedure::EarlyReturn(proc) => {
proc.expand(scope);
compile(scope);
}
}
}

Expand Down

0 comments on commit dd274b6

Please sign in to comment.