mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
clean up/ simplify
This commit is contained in:
parent
ce9bff21e9
commit
8f35ed11b5
4 changed files with 40 additions and 71 deletions
|
@ -17,8 +17,8 @@
|
|||
from migen.fhdl.std import *
|
||||
from migen.bus import csr
|
||||
from migen.bank import csrgen
|
||||
from miscope.std.misc import *
|
||||
|
||||
from miscope.std.misc import *
|
||||
from miscope.triggering import *
|
||||
from miscope.recording import *
|
||||
from miscope import miio, mila
|
||||
|
@ -78,8 +78,13 @@ class SoC(Module):
|
|||
# Misc
|
||||
self.cnt = Signal(9)
|
||||
self.submodules.freqgen = FreqGen(clk_freq, 500*KHz)
|
||||
self.submodules.eventgen_rising = EventGen(self.freqgen.o, RISING_EDGE, clk_freq, 100*ns)
|
||||
self.submodules.eventgen_falling = EventGen(self.freqgen.o, FALLING_EDGE, clk_freq, 100*ns)
|
||||
self.submodules.eventgen_rising = EventGen(RISING_EDGE, clk_freq, 100*ns)
|
||||
self.submodules.eventgen_falling = EventGen(FALLING_EDGE, clk_freq, 100*ns)
|
||||
self.comb += [
|
||||
self.eventgen_rising.i.eq(self.freqgen.o),
|
||||
self.eventgen_falling.i.eq(self.freqgen.o)
|
||||
]
|
||||
|
||||
|
||||
###
|
||||
|
||||
|
|
|
@ -1,11 +0,0 @@
|
|||
def dec2bin(d, nb=0):
|
||||
if d=="x":
|
||||
return "x"*nb
|
||||
elif d==0:
|
||||
b="0"
|
||||
else:
|
||||
b=""
|
||||
while d!=0:
|
||||
b="01"[d&1]+b
|
||||
d=d>>1
|
||||
return b.zfill(nb)
|
|
@ -1,37 +1,41 @@
|
|||
from migen.fhdl.std import *
|
||||
|
||||
def ifthenelse(cond, r1, r2):
|
||||
if cond != False and cond is not None:
|
||||
return r1
|
||||
def dec2bin(d, nb=0):
|
||||
if d=="x":
|
||||
return "x"*nb
|
||||
elif d==0:
|
||||
b="0"
|
||||
else:
|
||||
return r2
|
||||
b=""
|
||||
while d!=0:
|
||||
b="01"[d&1]+b
|
||||
d=d>>1
|
||||
return b.zfill(nb)
|
||||
|
||||
class RisingEdge(Module):
|
||||
def __init__(self, i=None, o=None):
|
||||
self.i = ifthenelse(i, i, Signal())
|
||||
self.o = ifthenelse(o, o, Signal())
|
||||
def __init__(self):
|
||||
self.i = Signal()
|
||||
self.o = Signal()
|
||||
####
|
||||
i_d = Signal()
|
||||
self.sync += i_d.eq(self.i)
|
||||
self.comb += self.o.eq(self.i & ~i_d)
|
||||
|
||||
class FallingEdge(Module):
|
||||
def __init__(self, i=None, o=None, domain="sys"):
|
||||
self.i = ifthenelse(i, i, Signal())
|
||||
self.o = ifthenelse(o, o, Signal())
|
||||
def __init__(self):
|
||||
self.i = Signal()
|
||||
self.o = Signal()
|
||||
####
|
||||
i_d = Signal()
|
||||
self.sync += i_d.eq(self.i)
|
||||
self.comb += self.o.eq(~self.i & i_d)
|
||||
|
||||
class FreqGen(Module):
|
||||
def __init__(self, clk_freq, freq, o=None):
|
||||
def __init__(self, clk_freq, freq):
|
||||
cnt_max = int(clk_freq/freq/2)
|
||||
width = bits_for(cnt_max)
|
||||
|
||||
self.o = ifthenelse(o, o, Signal())
|
||||
self.o = Signal()
|
||||
####
|
||||
cnt = Signal(width)
|
||||
cnt = Signal(max=cnt_max)
|
||||
self.sync += [
|
||||
If(cnt >= cnt_max,
|
||||
cnt.eq(0),
|
||||
|
@ -39,30 +43,27 @@ class FreqGen(Module):
|
|||
).Else(
|
||||
cnt.eq(cnt+1)
|
||||
)
|
||||
]
|
||||
]
|
||||
|
||||
RISING_EDGE = 1
|
||||
FALLING_EDGE = 0
|
||||
|
||||
class EventGen(Module):
|
||||
def __init__(self, i=None, level=1, clk_freq=0, length=1, o=None):
|
||||
|
||||
def __init__(self, level=RISING_EDGE, clk_freq=0, length=1):
|
||||
cnt_max = int(length*clk_freq)
|
||||
width = bits_for(cnt_max)
|
||||
|
||||
self.i = ifthenelse(i, i, Signal())
|
||||
self.o = ifthenelse(o, o, Signal())
|
||||
self.o = Signal()
|
||||
###
|
||||
cnt = Signal(width)
|
||||
i_edge = Signal()
|
||||
cnt = Signal(max=cnt_max)
|
||||
|
||||
if level == RISING_EDGE:
|
||||
self.submodules += RisingEdge(self.i, i_edge)
|
||||
self.submodules.edge_detect = RisingEdge()
|
||||
elif level == FALLING_EDGE:
|
||||
self.submodules += FallingEdge(self.i, i_edge)
|
||||
self.submodules.edge_detect = FallingEdge()
|
||||
|
||||
self.i = self.edge_detect.i
|
||||
|
||||
self.sync += [
|
||||
If(i_edge == 1,
|
||||
If(self.edge_detect.o == 1,
|
||||
cnt.eq(0),
|
||||
self.o.eq(1)
|
||||
).Elif(cnt >= cnt_max,
|
||||
|
@ -73,9 +74,9 @@ class EventGen(Module):
|
|||
]
|
||||
|
||||
class PwmGen(Module):
|
||||
def __init__(self, width, o=None):
|
||||
def __init__(self, width):
|
||||
self.ratio = Signal(width)
|
||||
self.o = ifthenelse(o, o, Signal())
|
||||
self.o = Signal()
|
||||
###
|
||||
cnt = Signal(width)
|
||||
self.sync += [
|
||||
|
@ -85,30 +86,4 @@ class PwmGen(Module):
|
|||
self.o.eq(0)
|
||||
),
|
||||
cnt.eq(cnt+1)
|
||||
]
|
||||
|
||||
class Cascade(Module):
|
||||
def __init__(self, i=None, elements=None, o=None):
|
||||
self.i = ifthenelse(i, i, Signal())
|
||||
self.o = ifthenelse(o, o, Signal())
|
||||
self.comb +=[elements[0].i.eq(self.i)]
|
||||
self.comb +=[elements[i+1].i.eq(elements[i].o) for i in range(len(elements)-1)]
|
||||
self.comb +=[self.o.eq(elements[len(elements)-1].o)]
|
||||
|
||||
class PwrOnRst(Module):
|
||||
def __init__(self, width, rst=None, simulation=False):
|
||||
self.rst = ifthenelse(rst, rst, Signal())
|
||||
###
|
||||
cnt = Signal(width)
|
||||
sync_no_reset = [If(self.rst, cnt.eq(cnt+1))]
|
||||
if not simulation:
|
||||
self.comb +=[
|
||||
If(cnt >= (2**width-1),
|
||||
self.rst.eq(0)
|
||||
).Else(
|
||||
self.rst.eq(1)
|
||||
)
|
||||
]
|
||||
else:
|
||||
self.comb += self.rst.eq(0)
|
||||
self._fragment += Fragment(sync={"sys_no_reset" : sync_no_reset})
|
||||
]
|
|
@ -1,7 +1,7 @@
|
|||
import sys
|
||||
import datetime
|
||||
|
||||
from miscope.tools.conv import *
|
||||
from miscope.tools.misc import *
|
||||
|
||||
def get_bits(values, width, low, high=None):
|
||||
r = []
|
||||
|
|
Loading…
Reference in a new issue