mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
adapt migScope to Migen changes
This commit is contained in:
parent
f96a28fc32
commit
e6042c122c
10 changed files with 108 additions and 74 deletions
|
@ -4,7 +4,7 @@ class Constraints:
|
|||
def add(signal, pin, vec=-1, iostandard="3.3-V LVTTL", extra="", sch=""):
|
||||
self.constraints.append((signal, vec, pin, iostandard, extra,sch))
|
||||
def add_vec(signal, pins, iostandard="3.3-V LVTTL", extra="", sch=""):
|
||||
assert(signal.bv.width == len(pins)), "%s size : %d / qsf size : %d" %(signal,signal.bv.width,len(pins))
|
||||
assert(signal.nbits == len(pins)), "%s size : %d / qsf size : %d" %(signal,signal.bv.width,len(pins))
|
||||
i = 0
|
||||
for p in pins:
|
||||
add(signal, p, i, iostandard, extra)
|
||||
|
|
|
@ -102,11 +102,11 @@ def get():
|
|||
# Csr Interconnect
|
||||
csrcon0 = csr.Interconnect(spi2csr0.csr,
|
||||
[
|
||||
migIo0.bank.interface,
|
||||
migLa0.trig.bank.interface,
|
||||
migLa0.rec.bank.interface,
|
||||
migLa1.trig.bank.interface,
|
||||
migLa1.rec.bank.interface,
|
||||
migIo0.bank.bus,
|
||||
migLa0.trig.bank.bus,
|
||||
migLa0.rec.bank.bus,
|
||||
migLa1.trig.bank.bus,
|
||||
migLa1.rec.bank.bus,
|
||||
|
||||
])
|
||||
comb = []
|
||||
|
@ -117,13 +117,13 @@ def get():
|
|||
#
|
||||
|
||||
# Counter
|
||||
cnt_gen = Signal(BV(8))
|
||||
cnt_gen = Signal(8)
|
||||
sync += [
|
||||
cnt_gen.eq(cnt_gen+1)
|
||||
]
|
||||
|
||||
# Square
|
||||
square_gen = Signal(BV(8))
|
||||
square_gen = Signal(8)
|
||||
sync += [
|
||||
If(cnt_gen[7],
|
||||
square_gen.eq(255)
|
||||
|
@ -134,13 +134,18 @@ def get():
|
|||
|
||||
sinus = [int(128*sin((2*3.1415)/256*(x+1)))+128 for x in range(256)]
|
||||
sinus_re = Signal()
|
||||
sinus_gen = Signal(BV(8))
|
||||
sinus_gen = Signal(8)
|
||||
comb +=[sinus_re.eq(1)]
|
||||
sinus_port = MemoryPort(adr=cnt_gen, re=sinus_re, dat_r=sinus_gen)
|
||||
sinus_mem = Memory(8, 256, sinus_port, init = sinus)
|
||||
sinus_mem = Memory(8, 256, init = sinus)
|
||||
sinus_port = sinus_mem.get_port(has_re=True)
|
||||
comb += [
|
||||
sinus_port.adr.eq(cnt_gen),
|
||||
sinus_port.re.eq(sinus_re),
|
||||
sinus_gen.eq(sinus_port.dat_r)
|
||||
]
|
||||
|
||||
# Signal Selection
|
||||
sig_gen = Signal(BV(8))
|
||||
sig_gen = Signal(8)
|
||||
comb += [
|
||||
If(migIo0.o == 0,
|
||||
sig_gen.eq(cnt_gen)
|
||||
|
@ -154,7 +159,7 @@ def get():
|
|||
]
|
||||
|
||||
# Led
|
||||
led0 = Signal(BV(8))
|
||||
led0 = Signal(8)
|
||||
comb += [led0.eq(migIo0.o[:8])]
|
||||
|
||||
|
||||
|
@ -187,7 +192,7 @@ def get():
|
|||
cst = Constraints(in_rst_n, cd_in, spi2csr0, led0)
|
||||
src_verilog, vns = verilog.convert(frag,
|
||||
cst.get_ios(),
|
||||
name="de1",
|
||||
name="de0_nano",
|
||||
clock_domains={
|
||||
"sys": cd_in
|
||||
},
|
||||
|
|
|
@ -4,7 +4,7 @@ class Constraints:
|
|||
def add(signal, pin, vec=-1, iostandard="3.3-V LVTTL", extra="", sch=""):
|
||||
self.constraints.append((signal, vec, pin, iostandard, extra,sch))
|
||||
def add_vec(signal, pins, iostandard="3.3-V LVTTL", extra="", sch=""):
|
||||
assert(signal.bv.width == len(pins)), "%s size : %d / qsf size : %d" %(signal,signal.bv.width,len(pins))
|
||||
assert(signal.nbits == len(pins)), "%s size : %d / qsf size : %d" %(signal,signal.bv.width,len(pins))
|
||||
i = 0
|
||||
for p in pins:
|
||||
add(signal, p, i, iostandard, extra)
|
||||
|
|
|
@ -102,11 +102,11 @@ def get():
|
|||
# Csr Interconnect
|
||||
csrcon0 = csr.Interconnect(spi2csr0.csr,
|
||||
[
|
||||
migIo0.bank.interface,
|
||||
migLa0.trig.bank.interface,
|
||||
migLa0.rec.bank.interface,
|
||||
migLa1.trig.bank.interface,
|
||||
migLa1.rec.bank.interface,
|
||||
migIo0.bank.bus,
|
||||
migLa0.trig.bank.bus,
|
||||
migLa0.rec.bank.bus,
|
||||
migLa1.trig.bank.bus,
|
||||
migLa1.rec.bank.bus,
|
||||
|
||||
])
|
||||
comb = []
|
||||
|
@ -117,13 +117,13 @@ def get():
|
|||
#
|
||||
|
||||
# Counter
|
||||
cnt_gen = Signal(BV(8))
|
||||
cnt_gen = Signal(8)
|
||||
sync += [
|
||||
cnt_gen.eq(cnt_gen+1)
|
||||
]
|
||||
|
||||
# Square
|
||||
square_gen = Signal(BV(8))
|
||||
square_gen = Signal(8)
|
||||
sync += [
|
||||
If(cnt_gen[7],
|
||||
square_gen.eq(255)
|
||||
|
@ -134,13 +134,18 @@ def get():
|
|||
|
||||
sinus = [int(128*sin((2*3.1415)/256*(x+1)))+128 for x in range(256)]
|
||||
sinus_re = Signal()
|
||||
sinus_gen = Signal(BV(8))
|
||||
sinus_gen = Signal(8)
|
||||
comb +=[sinus_re.eq(1)]
|
||||
sinus_port = MemoryPort(adr=cnt_gen, re=sinus_re, dat_r=sinus_gen)
|
||||
sinus_mem = Memory(8, 256, sinus_port, init = sinus)
|
||||
sinus_mem = Memory(8, 256, init = sinus)
|
||||
sinus_port = sinus_mem.get_port(has_re=True)
|
||||
comb += [
|
||||
sinus_port.adr.eq(cnt_gen),
|
||||
sinus_port.re.eq(sinus_re),
|
||||
sinus_gen.eq(sinus_port.dat_r)
|
||||
]
|
||||
|
||||
# Signal Selection
|
||||
sig_gen = Signal(BV(8))
|
||||
sig_gen = Signal(8)
|
||||
comb += [
|
||||
If(migIo0.o == 0,
|
||||
sig_gen.eq(cnt_gen)
|
||||
|
@ -154,11 +159,11 @@ def get():
|
|||
]
|
||||
|
||||
# Led
|
||||
led0 = Signal(BV(8))
|
||||
led0 = Signal(8)
|
||||
comb += [led0.eq(migIo0.o[:8])]
|
||||
|
||||
#Switch
|
||||
sw0 = Signal(BV(8))
|
||||
sw0 = Signal(8)
|
||||
comb += [migIo0.i.eq(sw0)]
|
||||
|
||||
# MigLa0 input
|
||||
|
|
|
@ -15,11 +15,11 @@ class MigIo:
|
|||
self.interface = interface
|
||||
self.words = int(2**bits_for(width-1)/8)
|
||||
if "I" in self.mode:
|
||||
self.i = Signal(BV(self.width))
|
||||
self.i = Signal(self.width)
|
||||
self.ireg = description.RegisterField("i", self.width, READ_ONLY, WRITE_ONLY)
|
||||
self.ireg.field.w.name_override = "inputs"
|
||||
if "O" in self.mode:
|
||||
self.o = Signal(BV(self.width))
|
||||
self.o = Signal(self.width)
|
||||
self.oreg = description.RegisterField("o", self.width)
|
||||
self.oreg.field.r.name_override = "ouptuts"
|
||||
self.bank = csrgen.Bank([self.oreg, self.ireg], address=self.address)
|
||||
|
|
|
@ -15,8 +15,8 @@ class MigLa:
|
|||
self.rec = rec
|
||||
self.interface = interface
|
||||
|
||||
self.in_trig = Signal(BV(self.trig.trig_width))
|
||||
self.in_dat = Signal(BV(self.trig.trig_width))
|
||||
self.in_trig = Signal(self.trig.trig_width)
|
||||
self.in_dat = Signal(self.trig.trig_width)
|
||||
|
||||
self.trig.set_address(self.address)
|
||||
self.rec.set_address(self.address + 0x0200)
|
||||
|
|
|
@ -15,30 +15,43 @@ class Storage:
|
|||
#Control
|
||||
self.rst = Signal()
|
||||
self.start = Signal()
|
||||
self.offset = Signal(BV(self.depth_width))
|
||||
self.size = Signal(BV(self.depth_width))
|
||||
self.offset = Signal(self.depth_width)
|
||||
self.size = Signal(self.depth_width)
|
||||
self.done = Signal()
|
||||
self.run = Signal()
|
||||
|
||||
#Others
|
||||
self._mem = Memory(self.width, self.depth)
|
||||
|
||||
#Write Path
|
||||
self.put = Signal()
|
||||
self.put_dat = Signal(BV(self.width))
|
||||
self._put_ptr = Signal(BV(self.depth_width))
|
||||
self._put_ptr_stop = Signal(BV(self.depth_width))
|
||||
self._put_port = MemoryPort(adr=self._put_ptr, we=self.put, dat_w=self.put_dat)
|
||||
self.put_dat = Signal(self.width)
|
||||
self._put_ptr = Signal(self.depth_width)
|
||||
self._put_ptr_stop = Signal(self.depth_width)
|
||||
self._put_port = self._mem.get_port(write_capable=True)
|
||||
|
||||
#Read Path
|
||||
self.get = Signal()
|
||||
self.get_dat = Signal(BV(self.width))
|
||||
self._get_ptr = Signal(BV(self.depth_width))
|
||||
self._get_port = MemoryPort(adr=self._get_ptr, re=self.get, dat_r=self.get_dat)
|
||||
#Others
|
||||
self._mem = Memory(self.width, self.depth, self._put_port, self._get_port)
|
||||
self.get_dat = Signal(self.width)
|
||||
self._get_ptr = Signal(self.depth_width)
|
||||
self._get_port = self._mem.get_port(has_re=True)
|
||||
|
||||
|
||||
def get_fragment(self):
|
||||
comb = []
|
||||
sync = []
|
||||
memories = [self._mem]
|
||||
size_minus_offset = Signal(BV(self.depth_width))
|
||||
comb += [
|
||||
self._get_port.adr.eq(self._get_ptr),
|
||||
self._get_port.re.eq(self.get),
|
||||
self.get_dat.eq(self._get_port.dat_r),
|
||||
|
||||
self._put_port.adr.eq(self._put_ptr),
|
||||
self._put_port.we.eq(self.put),
|
||||
self._put_port.dat_w.eq(self.put_dat)
|
||||
]
|
||||
|
||||
size_minus_offset = Signal(self.depth_width)
|
||||
comb += [size_minus_offset.eq(self.size-self.offset)]
|
||||
|
||||
#Control
|
||||
|
@ -82,8 +95,8 @@ class Sequencer:
|
|||
self.depth_width = bits_for(self.depth)
|
||||
# Controller interface
|
||||
self.ctl_rst = Signal()
|
||||
self.ctl_offset = Signal(BV(self.depth_width))
|
||||
self.ctl_size = Signal(BV(self.depth_width))
|
||||
self.ctl_offset = Signal(self.depth_width)
|
||||
self.ctl_size = Signal(self.depth_width)
|
||||
self.ctl_arm = Signal()
|
||||
self.ctl_done = Signal()
|
||||
self._ctl_arm_d = Signal()
|
||||
|
@ -91,8 +104,8 @@ class Sequencer:
|
|||
self.trig_hit = Signal()
|
||||
self._trig_hit_d = Signal()
|
||||
# Recorder interface
|
||||
self.rec_offset = Signal(BV(self.depth_width))
|
||||
self.rec_size = Signal(BV(self.depth_width))
|
||||
self.rec_offset = Signal(self.depth_width)
|
||||
self.rec_size = Signal(self.depth_width)
|
||||
self.rec_start = Signal()
|
||||
self.rec_done = Signal()
|
||||
# Others
|
||||
|
@ -154,7 +167,7 @@ class Recorder:
|
|||
|
||||
# Trigger Interface
|
||||
self.trig_hit = Signal()
|
||||
self.trig_dat = Signal(BV(self.width))
|
||||
self.trig_dat = Signal(self.width)
|
||||
|
||||
def set_address(self, address):
|
||||
self.address = address
|
||||
|
|
|
@ -18,9 +18,9 @@ class Term:
|
|||
self.reg_size = 2*width
|
||||
self.words = int(2**bits_for(width-1)/8)
|
||||
|
||||
self.i = Signal(BV(self.width))
|
||||
self.t = Signal(BV(self.width))
|
||||
self.m = Signal(BV(self.width))
|
||||
self.i = Signal(self.width)
|
||||
self.t = Signal(self.width)
|
||||
self.m = Signal(self.width)
|
||||
self.o = Signal()
|
||||
|
||||
def get_fragment(self):
|
||||
|
@ -60,9 +60,9 @@ class RangeDetector:
|
|||
self.reg_size = 2*width
|
||||
self.words = int(2**bits_for(width-1)/8)
|
||||
|
||||
self.i = Signal(BV(self.width))
|
||||
self.low = Signal(BV(self.width))
|
||||
self.high = Signal(BV(self.width))
|
||||
self.i = Signal(self.width)
|
||||
self.low = Signal(self.width)
|
||||
self.high = Signal(self.width)
|
||||
self.o = Signal()
|
||||
|
||||
def get_fragment(self):
|
||||
|
@ -102,16 +102,16 @@ class EdgeDetector:
|
|||
self.reg_base = 0
|
||||
self.reg_size = len(self.mode)*width
|
||||
|
||||
self.i = Signal(BV(self.width))
|
||||
self.i_d = Signal(BV(self.width))
|
||||
self.i = Signal(self.width)
|
||||
self.i_d = Signal(self.width)
|
||||
if "R" in self.mode:
|
||||
self.r_mask = Signal(BV(self.width))
|
||||
self.r_mask = Signal(self.width)
|
||||
self.ro = Signal()
|
||||
if "F" in self.mode:
|
||||
self.f_mask = Signal(BV(self.width))
|
||||
self.f_mask = Signal(self.width)
|
||||
self.fo = Signal()
|
||||
if "B" in self.mode:
|
||||
self.b_mask = Signal(BV(self.width))
|
||||
self.b_mask = Signal(self.width)
|
||||
self.bo = Signal()
|
||||
self.o = Signal()
|
||||
|
||||
|
@ -206,8 +206,8 @@ class Timer:
|
|||
self.clear = Signal()
|
||||
|
||||
self.enable = Signal()
|
||||
self.cnt = Signal(BV(self.width))
|
||||
self.cnt_max = Signal(BV(self.width))
|
||||
self.cnt = Signal(self.width)
|
||||
self.cnt_max = Signal(self.width)
|
||||
|
||||
self.o = Signal()
|
||||
|
||||
|
@ -253,26 +253,37 @@ class Sum:
|
|||
self.pipe = pipe
|
||||
self.interface = None
|
||||
|
||||
self.i = Signal(BV(self.width))
|
||||
self._mem = Memory(1, 2**self.width)
|
||||
|
||||
self.i = Signal(self.width)
|
||||
self._o = Signal()
|
||||
self.o = Signal()
|
||||
self._lut_port = MemoryPort(adr=self.i, dat_r=self._o)
|
||||
self._lut_port = self._mem.get_port()
|
||||
|
||||
self.reg_name = "sum_reg"
|
||||
self.reg_base = 0
|
||||
self.reg_size = 32
|
||||
|
||||
self.prog = Signal()
|
||||
self.prog_adr = Signal(BV(width))
|
||||
self.prog_adr = Signal(width)
|
||||
self.prog_dat = Signal()
|
||||
self._prog_port = MemoryPort(adr=self.prog_adr, we=self.prog, dat_w=self.prog_dat)
|
||||
self._prog_port = self._mem.get_port(write_capable=True)
|
||||
|
||||
self._mem = Memory(1, 2**self.width, self._lut_port, self._prog_port)
|
||||
|
||||
def get_fragment(self):
|
||||
comb = []
|
||||
sync = []
|
||||
memories = [self._mem]
|
||||
comb += [
|
||||
self._lut_port.adr.eq(self.i),
|
||||
self._o.eq(self._lut_port.dat_r),
|
||||
|
||||
self._prog_port.adr.eq(self.prog_adr),
|
||||
self._prog_port.we.eq(self.prog),
|
||||
self._prog_port.dat_w.eq(self.prog_dat)
|
||||
]
|
||||
|
||||
|
||||
if self.pipe:
|
||||
sync += [self.o.eq(self._o)]
|
||||
else:
|
||||
|
@ -311,7 +322,7 @@ class Trigger:
|
|||
self.interface = interface
|
||||
self.sum = Sum(len(self.ports))
|
||||
|
||||
self.in_trig = Signal(BV(self.trig_width))
|
||||
self.in_trig = Signal(self.trig_width)
|
||||
|
||||
self.hit = Signal()
|
||||
|
||||
|
|
|
@ -125,7 +125,7 @@ def main():
|
|||
recorder0.bank.interface
|
||||
])
|
||||
|
||||
trig_sig = Signal(BV(32))
|
||||
trig_sig = Signal(32)
|
||||
comb = []
|
||||
comb +=[
|
||||
trigger0.in_trig.eq(trig_sig)
|
||||
|
|
|
@ -68,10 +68,10 @@ class Spi2Csr :
|
|||
#
|
||||
# Spi --> Csr
|
||||
#
|
||||
spi_cnt = Signal(BV(bits_for(self.a_width+self.max_burst*self.d_width)))
|
||||
spi_addr = Signal(BV(self.a_width))
|
||||
spi_w_dat = Signal(BV(self.d_width))
|
||||
spi_r_dat = Signal(BV(self.d_width))
|
||||
spi_cnt = Signal(bits_for(self.a_width+self.max_burst*self.d_width))
|
||||
spi_addr = Signal(self.a_width)
|
||||
spi_w_dat = Signal(self.d_width)
|
||||
spi_r_dat = Signal(self.d_width)
|
||||
spi_we = Signal()
|
||||
spi_re = Signal()
|
||||
spi_we_re_done = Signal(reset = 1)
|
||||
|
@ -126,7 +126,7 @@ class Spi2Csr :
|
|||
#
|
||||
# Csr --> Spi
|
||||
#
|
||||
spi_r_dat_shift = Signal(BV(self.d_width))
|
||||
spi_r_dat_shift = Signal(self.d_width)
|
||||
sync +=[
|
||||
If(spi_re,
|
||||
spi_r_dat_shift.eq(spi_r_dat)
|
||||
|
|
Loading…
Reference in a new issue