soc/cores/spi: use new CSRField (no functional change)

This commit is contained in:
Florent Kermarrec 2019-09-16 17:02:55 +02:00
parent 80b2bef387
commit cca0478a5e
2 changed files with 9 additions and 11 deletions

View File

@ -10,11 +10,6 @@ from litex.soc.interconnect.csr import *
# SPI Master --------------------------------------------------------------------------------------- # SPI Master ---------------------------------------------------------------------------------------
SPI_CONTROL_START = 0
SPI_CONTROL_LENGTH = 8
SPI_STATUS_DONE = 0
class SPIMaster(Module, AutoCSR): class SPIMaster(Module, AutoCSR):
"""4-wire SPI Master """4-wire SPI Master
@ -129,21 +124,24 @@ class SPIMaster(Module, AutoCSR):
) )
def add_csr(self): def add_csr(self):
self._control = CSRStorage(16) self._control = CSRStorage(fields=[
self._status = CSRStatus() CSRField("start", size=1, offset=0, pulse=True),
CSRField("length", size=8, offset=8)])
self._status = CSRStatus(fields=[
CSRField("done", size=1, offset=0)])
self._mosi = CSRStorage(self.data_width) self._mosi = CSRStorage(self.data_width)
self._miso = CSRStatus(self.data_width) self._miso = CSRStatus(self.data_width)
self._cs = CSRStorage(len(self.cs), reset=1) self._cs = CSRStorage(len(self.cs), reset=1)
self._loopback = CSRStorage() self._loopback = CSRStorage()
self.comb += [ self.comb += [
self.start.eq(self._control.re & self._control.storage[SPI_CONTROL_START]), self.start.eq(self._control.fields.start),
self.length.eq(self._control.storage[SPI_CONTROL_LENGTH:]), self.length.eq(self._control.fields.length),
self.mosi.eq(self._mosi.storage), self.mosi.eq(self._mosi.storage),
self.cs.eq(self._cs.storage), self.cs.eq(self._cs.storage),
self.loopback.eq(self._loopback.storage), self.loopback.eq(self._loopback.storage),
self._status.status[SPI_STATUS_DONE].eq(self.done), self._status.fields.done.eq(self.done),
self._miso.status.eq(self.miso), self._miso.status.eq(self.miso),
] ]

View File

@ -360,7 +360,7 @@ class CSRStorage(_CompoundCSR):
for field in [*fields]: for field in [*fields]:
field_assign = getattr(self.fields, field.name).eq(self.storage[field.offset:field.offset + field.size]) field_assign = getattr(self.fields, field.name).eq(self.storage[field.offset:field.offset + field.size])
if field.pulse: if field.pulse:
self.comb += If(self.storage.re, field_assign) self.comb += If(self.re, field_assign)
else: else:
self.comb += field_assign self.comb += field_assign