litex/milkymist/dvisampler/__init__.py

31 lines
834 B
Python
Raw Normal View History

2013-03-13 14:56:26 -04:00
from migen.fhdl.structure import *
from migen.fhdl.module import Module
from migen.bank.description import *
from milkymist.dvisampler.edid import EDID
from milkymist.dvisampler.clocking import Clocking
from milkymist.dvisampler.datacapture import DataCapture
2013-03-13 14:56:26 -04:00
class DVISampler(Module, AutoReg):
def __init__(self, inversions=""):
self.submodules.edid = EDID()
self.sda = self.edid.sda
self.scl = self.edid.scl
self.submodules.clocking = Clocking()
self.clk = self.clocking.clkin
2013-03-13 14:56:26 -04:00
for datan in "012":
name = "data" + str(datan)
invert = datan in inversions
cap = DataCapture(8, invert)
setattr(self.submodules, name + "_cap", cap)
if invert:
2013-03-13 14:56:26 -04:00
name += "_n"
s = Signal(name=name)
setattr(self, name, s)
self.comb += [
cap.pad.eq(s),
2013-03-18 14:03:17 -04:00
cap.serdesstrobe.eq(self.clocking.serdesstrobe)
]