Skip to content

Commit

Permalink
Merge branch 'main' into gen-msb-tidying
Browse files Browse the repository at this point in the history
  • Loading branch information
anshumanmohan authored May 16, 2024
2 parents 56a76b1 + 1be68ce commit fd97fbd
Show file tree
Hide file tree
Showing 23 changed files with 1,095 additions and 296 deletions.
23 changes: 18 additions & 5 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

5 changes: 3 additions & 2 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,10 @@ members = [
"tools/data_gen",
"cider-dap",
"fud2",
"fud2/fud-core",
"fud2/fud-core",
"data-conversion",
"tools/btor2/btor2i"
"tools/btor2/btor2i",
"tools/cider-data-converter",
]
exclude = ["site"]

Expand Down
14 changes: 4 additions & 10 deletions calyx-py/calyx/builder.py
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,9 @@ def __init__(self):
self.import_("primitives/core.futil")
self._index: Dict[str, ComponentBuilder] = {}

def component(self, name: str, cells=None, latency=None) -> ComponentBuilder:
def component(self, name: str, latency=None) -> ComponentBuilder:
"""Create a new component builder."""
cells = cells or []
comp_builder = ComponentBuilder(self, name, cells, latency)
comp_builder = ComponentBuilder(self, name, latency)
self.program.components.append(comp_builder.component)
self._index[name] = comp_builder
return comp_builder
Expand Down Expand Up @@ -67,25 +66,20 @@ def __init__(
self,
prog: Builder,
name: str,
cells: Optional[List[ast.Cell]] = None,
latency: Optional[int] = None,
):
"""Contructs a new component in the current program. If `cells` is
provided, the component will be initialized with those cells."""
cells = cells if cells else list()
"""Contructs a new component in the current program."""
self.prog = prog
self.component: ast.Component = ast.Component(
name,
attributes=[],
inputs=[],
outputs=[],
structs=cells,
structs=list(),
controls=ast.Empty(),
latency=latency,
)
self.index: Dict[str, Union[GroupBuilder, CellBuilder]] = {}
for cell in cells:
self.index[cell.id.name] = CellBuilder(cell)
self.continuous = GroupBuilder(None, self)
self.next_gen_idx = 0

Expand Down
5 changes: 5 additions & 0 deletions interp/src/errors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -180,6 +180,11 @@ pub enum InterpreterError {
// TODO Griffin: Make this more descriptive
#[error("Attempted to read an undefined memory address")]
UndefinedReadAddr,

#[error(transparent)]
SerializationError(
#[from] crate::serialization::data_dump::SerializationError,
),
}

impl InterpreterError {
Expand Down
190 changes: 132 additions & 58 deletions interp/src/flatten/flat_ir/cell_prototype.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
use calyx_ir::{self as cir};
use smallvec::SmallVec;

use crate::primitives::prim_utils::get_params;
use crate::{
primitives::prim_utils::get_params, serialization::data_dump::Dimensions,
};

use super::prelude::ComponentIdx;

Expand Down Expand Up @@ -82,6 +84,101 @@ pub enum MemType {
Std,
}

#[derive(Debug, Clone)]
pub enum MemoryDimensions {
D1 {
d0_size: Width,
d0_idx_size: Width,
},
D2 {
d0_size: Width,
d0_idx_size: Width,
d1_size: Width,
d1_idx_size: Width,
},
D3 {
d0_size: Width,
d0_idx_size: Width,
d1_size: Width,
d1_idx_size: Width,
d2_size: Width,
d2_idx_size: Width,
},
D4 {
d0_size: Width,
d0_idx_size: Width,
d1_size: Width,
d1_idx_size: Width,
d2_size: Width,
d2_idx_size: Width,
d3_size: Width,
d3_idx_size: Width,
},
}

impl MemoryDimensions {
pub fn size(&self) -> usize {
match self {
Self::D1 { d0_size, .. } => *d0_size as usize,
Self::D2 {
d0_size, d1_size, ..
} => *d0_size as usize * *d1_size as usize,
Self::D3 {
d0_size,
d1_size,
d2_size,
..
} => *d0_size as usize * *d1_size as usize * *d2_size as usize,
Self::D4 {
d0_size,
d1_size,
d2_size,
d3_size,
..
} => {
*d0_size as usize
* *d1_size as usize
* *d2_size as usize
* *d3_size as usize
}
}
}

/// Returns a Dimensions object
pub fn as_serializing_dim(&self) -> Dimensions {
match self {
MemoryDimensions::D1 { d0_size, .. } => {
Dimensions::D1(*d0_size as usize)
}
MemoryDimensions::D2 {
d0_size, d1_size, ..
} => Dimensions::D2(*d0_size as usize, *d1_size as usize),
MemoryDimensions::D3 {
d0_size,
d1_size,
d2_size,
..
} => Dimensions::D3(
*d0_size as usize,
*d1_size as usize,
*d2_size as usize,
),
MemoryDimensions::D4 {
d0_size,
d1_size,
d2_size,
d3_size,
..
} => Dimensions::D4(
*d0_size as usize,
*d1_size as usize,
*d2_size as usize,
*d3_size as usize,
),
}
}
}

/// A type alias to allow potential space hacks
pub type Width = u32;

Expand Down Expand Up @@ -118,41 +215,10 @@ pub enum CellPrototype {
out: Width,
},
// Memories
MemD1 {
mem_type: MemType,
width: Width,
size: Width,
idx_size: Width,
},
MemD2 {
Memory {
mem_type: MemType,
width: Width,
d0_size: Width,
d1_size: Width,
d0_idx_size: Width,
d1_idx_size: Width,
},
MemD3 {
mem_type: MemType,
width: Width,
d0_size: Width,
d1_size: Width,
d2_size: Width,
d0_idx_size: Width,
d1_idx_size: Width,
d2_idx_size: Width,
},
MemD4 {
mem_type: MemType,
width: Width,
d0_size: Width,
d1_size: Width,
d2_size: Width,
d3_size: Width,
d0_idx_size: Width,
d1_idx_size: Width,
d2_idx_size: Width,
d3_idx_size: Width,
dims: MemoryDimensions,
},

// TODO Griffin: lots more
Expand Down Expand Up @@ -463,15 +529,17 @@ impl CellPrototype {
size: "SIZE",
idx_size: "IDX_SIZE"
];
Self::MemD1 {
Self::Memory {
mem_type: if n == "comb_mem_d1" {
MemType::Std
} else {
MemType::Seq
},
width: width.try_into().unwrap(),
size: size.try_into().unwrap(),
idx_size: idx_size.try_into().unwrap(),
dims: MemoryDimensions::D1 {
d0_size: size.try_into().unwrap(),
d0_idx_size: idx_size.try_into().unwrap(),
},
}
}
n @ ("comb_mem_d2" | "seq_mem_d2") => {
Expand All @@ -482,17 +550,19 @@ impl CellPrototype {
d0_idx_size: "D0_IDX_SIZE",
d1_idx_size: "D1_IDX_SIZE"
];
Self::MemD2 {
Self::Memory {
mem_type: if n == "comb_mem_d2" {
MemType::Std
} else {
MemType::Seq
},
width: width.try_into().unwrap(),
d0_size: d0_size.try_into().unwrap(),
d1_size: d1_size.try_into().unwrap(),
d0_idx_size: d0_idx_size.try_into().unwrap(),
d1_idx_size: d1_idx_size.try_into().unwrap(),
dims: MemoryDimensions::D2 {
d0_size: d0_size.try_into().unwrap(),
d1_size: d1_size.try_into().unwrap(),
d0_idx_size: d0_idx_size.try_into().unwrap(),
d1_idx_size: d1_idx_size.try_into().unwrap(),
},
}
}
n @ ("comb_mem_d3" | "seq_mem_d3") => {
Expand All @@ -505,19 +575,21 @@ impl CellPrototype {
d1_idx_size: "D1_IDX_SIZE",
d2_idx_size: "D2_IDX_SIZE"
];
Self::MemD3 {
Self::Memory {
mem_type: if n == "comb_mem_d3" {
MemType::Std
} else {
MemType::Seq
},
width: width.try_into().unwrap(),
d0_size: d0_size.try_into().unwrap(),
d1_size: d1_size.try_into().unwrap(),
d2_size: d2_size.try_into().unwrap(),
d0_idx_size: d0_idx_size.try_into().unwrap(),
d1_idx_size: d1_idx_size.try_into().unwrap(),
d2_idx_size: d2_idx_size.try_into().unwrap(),
dims: MemoryDimensions::D3 {
d0_size: d0_size.try_into().unwrap(),
d1_size: d1_size.try_into().unwrap(),
d2_size: d2_size.try_into().unwrap(),
d0_idx_size: d0_idx_size.try_into().unwrap(),
d1_idx_size: d1_idx_size.try_into().unwrap(),
d2_idx_size: d2_idx_size.try_into().unwrap(),
},
}
}
n @ ("comb_mem_d4" | "seq_mem_d4") => {
Expand All @@ -533,21 +605,23 @@ impl CellPrototype {
d3_idx_size: "D3_IDX_SIZE"
];

Self::MemD4 {
Self::Memory {
mem_type: if n == "comb_mem_d4" {
MemType::Std
} else {
MemType::Seq
},
width: width.try_into().unwrap(),
d0_size: d0_size.try_into().unwrap(),
d1_size: d1_size.try_into().unwrap(),
d2_size: d2_size.try_into().unwrap(),
d3_size: d3_size.try_into().unwrap(),
d0_idx_size: d0_idx_size.try_into().unwrap(),
d1_idx_size: d1_idx_size.try_into().unwrap(),
d2_idx_size: d2_idx_size.try_into().unwrap(),
d3_idx_size: d3_idx_size.try_into().unwrap(),
dims: MemoryDimensions::D4 {
d0_size: d0_size.try_into().unwrap(),
d1_size: d1_size.try_into().unwrap(),
d2_size: d2_size.try_into().unwrap(),
d3_size: d3_size.try_into().unwrap(),
d0_idx_size: d0_idx_size.try_into().unwrap(),
d1_idx_size: d1_idx_size.try_into().unwrap(),
d2_idx_size: d2_idx_size.try_into().unwrap(),
d3_idx_size: d3_idx_size.try_into().unwrap(),
},
}
}
n @ ("std_unsyn_mult" | "std_unsyn_div" | "std_unsyn_smult"
Expand Down
2 changes: 1 addition & 1 deletion interp/src/flatten/flat_ir/component.rs
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,7 @@ pub struct AuxillaryComponentInfo {
pub signature: IndexRange<LocalPortOffset>,
/// the definitions created by this component
pub definitions: DefinitionRanges,
// -------------------

pub port_offset_map: SparseMap<LocalPortOffset, PortDefinitionIdx>,
pub ref_port_offset_map:
SparseMap<LocalRefPortOffset, RefPortDefinitionIdx>,
Expand Down
2 changes: 2 additions & 0 deletions interp/src/flatten/flat_ir/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,5 @@ pub(crate) mod prelude {
pub use super::identifier::Identifier;
pub use super::wires::core::*;
}

pub use control::translator::translate;
Loading

0 comments on commit fd97fbd

Please sign in to comment.