mirror of
https://github.com/supleed2/EIE4-FYP.git
synced 2024-12-22 22:25:50 +00:00
Update testSaw to match updated genSaw / dacDriver
This commit is contained in:
parent
06fc184cc5
commit
3190265343
54
testSaw.py
54
testSaw.py
|
@ -1,6 +1,8 @@
|
|||
from migen import *
|
||||
|
||||
from litex.soc.interconnect.csr import *
|
||||
from litex.soc.interconnect.stream import AsyncFIFO
|
||||
from migen.genlib.fifo import AsyncFIFO as MigenAsyncFIFO
|
||||
from litex.soc.integration.doc import ModuleDoc
|
||||
|
||||
# Test RGB Module ----------------------------------------------------------------------------------
|
||||
|
@ -13,55 +15,49 @@ class TestSaw(Module, AutoCSR, ModuleDoc):
|
|||
"""
|
||||
def __init__(self, platform, pads):
|
||||
platform.add_source("rtl/genSaw.sv")
|
||||
platform.add_source("rtl/pcmfifo.sv")
|
||||
platform.add_source("rtl/dacDriver.sv")
|
||||
|
||||
self.pads = pads
|
||||
self.targ = CSRStorage(size = 24, description="Target Frequency of the Sawtooth Wave")
|
||||
|
||||
# 48MHz Domain Signals
|
||||
self.backpressure_48 = Signal()
|
||||
self.leftrightaudio_48 = Signal(48)
|
||||
self.audioready_48 = Signal()
|
||||
self.backpressure_48 = Signal()
|
||||
self.sample_48 = Signal(16)
|
||||
self.audioready_48 = Signal()
|
||||
|
||||
# 36.864MHz Domain Signals
|
||||
self.readrequest_36 = Signal()
|
||||
self.leftrightaudio_36 = Signal(48)
|
||||
self.fifoempty_36 = Signal()
|
||||
self.dac_lrck = Signal()
|
||||
self.dac_bck = Signal()
|
||||
self.dac_data = Signal()
|
||||
self.readrequest_36 = Signal()
|
||||
self.sample_36 = Signal(16)
|
||||
self.fifoempty_36 = Signal()
|
||||
self.dac_lrck = Signal()
|
||||
self.dac_bck = Signal()
|
||||
self.dac_data = Signal()
|
||||
|
||||
# # #
|
||||
|
||||
self.specials += Instance("genSaw",
|
||||
i_i_clk48 = ClockSignal(),
|
||||
i_i_rst48_n = ~ResetSignal(),
|
||||
i_i_pause = self.backpressure_48,
|
||||
i_i_tf = self.targ.storage,
|
||||
o_o_lr = self.leftrightaudio_48,
|
||||
o_o_new_pulse = self.audioready_48,
|
||||
)
|
||||
|
||||
self.specials += Instance("pcmfifo",
|
||||
i_i_clk48 = ClockSignal(),
|
||||
i_i_rst48_n = ~ResetSignal(),
|
||||
i_i_dvalid = self.audioready_48,
|
||||
i_i_din = self.leftrightaudio_48,
|
||||
o_o_full = self.backpressure_48,
|
||||
# ^ 48MHz Domain, v 36MHz Domain
|
||||
i_i_clk36 = ClockSignal("dac"),
|
||||
i_i_rst36_n = ResetSignal("dac"),
|
||||
i_i_rdreq = self.readrequest_36,
|
||||
o_o_dout = self.leftrightaudio_36,
|
||||
o_o_empty = self.fifoempty_36,
|
||||
i_i_pause = self.backpressure_48,
|
||||
i_i_targetf = self.targ.storage,
|
||||
o_o_sample = self.sample_48,
|
||||
o_o_pulse = self.audioready_48,
|
||||
)
|
||||
|
||||
sample_fifo = ClockDomainsRenamer({"write": "sys", "read": "dac"})(MigenAsyncFIFO(48, 4))
|
||||
self.comb += self.backpressure_48.eq(~sample_fifo.writable)
|
||||
self.comb += sample_fifo.we.eq(self.audioready_48)
|
||||
self.comb += sample_fifo.din.eq(self.sample_48)
|
||||
self.comb += self.fifoempty_36.eq(~sample_fifo.readable)
|
||||
self.comb += sample_fifo.re.eq(self.readrequest_36)
|
||||
self.comb += self.sample_36.eq(sample_fifo.dout)
|
||||
self.submodules += sample_fifo
|
||||
|
||||
self.specials += Instance("dacDriver",
|
||||
i_i_clk36 = ClockSignal("dac"),
|
||||
i_i_rst36_n = ~ResetSignal("dac"),
|
||||
i_i_wait = self.fifoempty_36,
|
||||
i_i_lraudio = self.leftrightaudio_36,
|
||||
i_i_sample = self.sample_36,
|
||||
o_o_rdreq = self.readrequest_36,
|
||||
o_o_lrck = self.dac_lrck,
|
||||
o_o_bck = self.dac_bck,
|
||||
|
|
Loading…
Reference in a new issue