diff --git a/examples/vcd_wire_dump.rs b/examples/vcd_wire_dump.rs new file mode 100644 index 0000000..15a2eab --- /dev/null +++ b/examples/vcd_wire_dump.rs @@ -0,0 +1,70 @@ +use logical::dump::Vcd; +use logical::models::{ + gates::{Mux, XorGate}, + inputs::Switch, + outputs::Led, +}; +use logical::{Circuit, Ieee1164, Ieee1164Value, Signal}; + +fn main() { + let mut val = Ieee1164::Strong(Ieee1164Value::One); + + let xor = XorGate::default(); + let mux = Mux::default(); + let mut input1 = Switch::new_with_value(val); + let input2 = Switch::new_with_value(Ieee1164::Strong(Ieee1164Value::One)); + let mut mux_switch = Switch::new_with_value(Ieee1164::Strong(Ieee1164Value::Zero)); + let output = Led::default(); + + let mut sig_input_signal = Signal::new(); + sig_input_signal.connect_as_input(&input1.output); + sig_input_signal.connect_as_output(&xor.a); + + let mut sig_input_mux = Signal::new(); + sig_input_mux.connect_as_input(&input2.output); + sig_input_mux.connect_as_output(&mux.a); + + let mut sig_mux_switch = Signal::new(); + sig_mux_switch.connect_as_input(&mux_switch.output); + sig_mux_switch.connect_as_output(&mux.s); + + let mut sig_rec = Signal::new(); + sig_rec.connect_as_output(&mux.b); + sig_rec.connect_as_output(&output.input); + sig_rec.connect_as_input(&xor.z); + + let mut sig_mux_xor = Signal::new(); + sig_mux_xor.connect_as_input(&mux.z); + sig_mux_xor.connect_as_output(&xor.b); + + let mut circuit = Circuit::new(); + circuit.add_updater(&xor); + circuit.add_updater(&mux); + circuit.add_updater(&sig_input_signal); + circuit.add_updater(&sig_input_mux); + circuit.add_updater(&sig_mux_switch); + circuit.add_updater(&sig_rec); + circuit.add_updater(&sig_mux_xor); + + circuit.tick(); + circuit.tick(); + circuit.tick(); + mux_switch.set_value(Ieee1164::Strong(Ieee1164Value::One)); + circuit.tick(); + + let mut dumper = Vcd::new("VCD Example"); + + for i in 0..90 { + dumper.serialize_ports(&xor); + circuit.tick(); + circuit.tick(); + dumper.tick(); + dumper.tick(); + if i % 20 == 0 { + val = !val; + input1.set_value(val); + } + } + + dumper.dump("/home/marcel/a.vcd").unwrap(); +} diff --git a/src/port/mod.rs b/src/port/mod.rs index 374f8b0..ca75ce3 100644 --- a/src/port/mod.rs +++ b/src/port/mod.rs @@ -10,6 +10,6 @@ pub use self::portdirection::{Dir, InOut, Input, MaybeRead, MaybeWrite, Off, Out pub use self::pport::Port; #[derive(Debug)] -pub(self) struct InnerPort { +pub(crate) struct InnerPort { value: RwLock, } diff --git a/src/port/pport.rs b/src/port/pport.rs index e2c7892..9251a6b 100644 --- a/src/port/pport.rs +++ b/src/port/pport.rs @@ -5,11 +5,13 @@ use std::sync::{Arc, RwLock}; use super::InnerPort; use crate::direction::{Dir, InOut, Input, MaybeRead, MaybeWrite, Output, PortDirection, Read, Write}; +use crate::dump::IterValues; use crate::port::portconnector::PortConnector; +use crate::Ieee1164; #[derive(Debug, Clone)] pub struct Port { - pub(super) inner: Arc>, + pub(crate) inner: Arc>, _marker: PhantomData, } @@ -39,7 +41,7 @@ impl Port { } impl Port { - pub(super) fn new_with_arc(arc: Arc>) -> Self { + pub(crate) fn new_with_arc(arc: Arc>) -> Self { Port { inner: arc, _marker: PhantomData,