litex/miscope/miio.py

46 lines
1.1 KiB
Python
Raw Normal View History

2012-09-12 16:19:42 -04:00
from migen.fhdl.structure import *
from migen.bus import csr
2013-04-14 12:23:37 -04:00
from migen.bank import csrgen
2012-09-12 16:19:42 -04:00
from migen.bank.description import *
2013-06-02 09:15:47 -04:00
from miscope.tools.misc import *
2013-02-22 08:28:05 -05:00
class MiIo:
2012-09-17 11:00:47 -04:00
#
# Definition
#
2013-03-18 16:45:07 -04:00
def __init__(self, address, width, mode="IO", interface=None):
2012-09-13 07:14:27 -04:00
self.address = address
2012-09-12 16:19:42 -04:00
self.width = width
2013-03-18 16:45:07 -04:00
self.mode = mode.upper()
2012-09-14 06:57:09 -04:00
self.interface = interface
2013-03-18 16:45:07 -04:00
self.words = int((2**bits_for(width-1))/8)
2013-02-22 08:28:05 -05:00
2012-09-12 16:19:42 -04:00
if "I" in self.mode:
2013-01-03 16:57:26 -05:00
self.i = Signal(self.width)
2013-04-14 12:23:37 -04:00
self._r_i = CSRStatus(self.width)
2013-02-22 08:28:05 -05:00
2012-09-12 16:19:42 -04:00
if "O" in self.mode:
2013-01-03 16:57:26 -05:00
self.o = Signal(self.width)
2013-04-14 12:23:37 -04:00
self._r_o = CSRStorage(self.width)
2013-02-22 08:28:05 -05:00
2013-03-26 17:14:25 -04:00
self.bank = csrgen.Bank([self._r_o, self._r_i], address=self.address)
2012-09-17 11:00:47 -04:00
2012-09-12 16:19:42 -04:00
def get_fragment(self):
comb = []
2013-02-22 08:28:05 -05:00
2012-09-13 07:14:27 -04:00
if "I" in self.mode:
2013-04-14 12:23:37 -04:00
comb += [self._r_i.status.eq(self.i)]
2013-02-22 08:28:05 -05:00
2012-09-13 07:14:27 -04:00
if "O" in self.mode:
2013-04-14 12:23:37 -04:00
comb += [self.o.eq(self._r_o.storage)]
2013-02-22 08:28:05 -05:00
return Fragment(comb) + self.bank.get_fragment()
2012-09-17 11:00:47 -04:00
#
2013-03-22 07:35:12 -04:00
# Driver
2012-09-17 11:00:47 -04:00
#
2013-03-22 07:35:12 -04:00
def set(self, data):
2013-06-02 09:15:47 -04:00
self.interface.write(get_csr_base(self.bank), data)
2012-09-17 11:00:47 -04:00
2013-03-22 07:35:12 -04:00
def get(self):
2013-06-02 09:15:47 -04:00
return self.interface.read(get_csr_base(self.bank) + self.words)