litex/milkymist/gpio/__init__.py

21 lines
626 B
Python
Raw Normal View History

2013-05-16 11:43:20 -04:00
from migen.fhdl.structure import *
from migen.fhdl.module import Module
from migen.genlib.cdc import MultiReg
from migen.bank.description import *
class GPIOIn(Module, AutoCSR):
def __init__(self, signal):
self._r_in = CSRStatus(len(signal))
self.specials += MultiReg(signal, self._r_in.status)
class GPIOOut(Module, AutoCSR):
def __init__(self, signal):
self._r_out = CSRStorage(len(signal))
self.comb += signal.eq(self._r_out.storage)
class Blinker(Module):
def __init__(self, signal, divbits=26):
counter = Signal(divbits)
self.comb += signal.eq(counter[divbits-1])
self.sync += counter.eq(counter + 1)