humpback-dds/migen/fpga_config.py

76 lines
1.8 KiB
Python
Raw Normal View History

2020-08-09 02:03:47 +08:00
from humpback import HumpbackPlatform
from migen.fhdl.module import Module
2020-08-21 11:17:08 +08:00
from migen.fhdl.specials import Instance
from migen.fhdl.bitcontainer import value_bits_sign
from migen.genlib.io import *
from migen.build.lattice.common import LatticeiCE40DifferentialInputImpl
from migen.genlib.io import DifferentialInput
2020-08-09 02:03:47 +08:00
class UrukulConnector(Module):
def __init__(self, platform):
# Request EEM I/O & SPI
2020-08-23 17:17:09 +08:00
eem0 = [
platform.request("eem0", 0),
platform.request("eem0", 1),
platform.request("eem0_n", 2),
platform.request("eem0", 3),
platform.request("eem0", 4),
2020-08-23 22:28:32 +08:00
platform.request("eem0", 5),
platform.request("eem0", 6)
2020-08-23 17:17:09 +08:00
]
2020-08-09 02:03:47 +08:00
spi = platform.request("spi")
2020-08-20 09:53:39 +08:00
led = platform.request("user_led")
2020-08-23 22:28:32 +08:00
io_update = platform.request("io_update")
2020-08-09 02:03:47 +08:00
2020-08-23 17:17:09 +08:00
# Assert SPI resource length
2020-08-09 02:03:47 +08:00
assert len(spi.sclk) == 1
assert len(spi.mosi) == 1
2020-08-23 17:17:09 +08:00
assert len(spi.miso) == 1
2020-08-09 02:03:47 +08:00
assert len(spi.cs) == 3
2020-08-23 17:17:09 +08:00
# TODO: Assert EEM resources
assert isinstance(eem0, list)
2020-08-20 09:53:39 +08:00
# Flip positive signal as negative output, maybe only do it for FPGA outputs
2020-08-21 11:36:16 +08:00
self.miso_n = Signal()
2020-08-21 11:17:08 +08:00
2020-08-23 17:17:09 +08:00
# Very similar setup to Diff setup for iCE40 suggested, but gave B pin instead
2020-08-21 11:17:08 +08:00
self.specials += Instance("SB_IO",
p_PIN_TYPE=C(0b000001, 6),
p_IO_STANDARD="SB_LVDS_INPUT",
2020-08-23 17:17:09 +08:00
io_PACKAGE_PIN=eem0[2],
2020-08-21 11:36:16 +08:00
o_D_IN_0=self.miso_n
2020-08-21 11:17:08 +08:00
)
2020-08-09 02:03:47 +08:00
# Link EEM to SPI
self.comb += [
2020-08-20 09:53:39 +08:00
2020-08-23 17:17:09 +08:00
eem0[0].p.eq(spi.sclk),
eem0[0].n.eq(~spi.sclk),
2020-08-20 09:53:39 +08:00
2020-08-23 17:17:09 +08:00
eem0[1].p.eq(spi.mosi),
eem0[1].n.eq(~spi.mosi),
2020-08-20 09:53:39 +08:00
2020-08-21 11:36:16 +08:00
spi.miso.eq(~self.miso_n),
2020-08-20 09:53:39 +08:00
2020-08-23 17:17:09 +08:00
eem0[3].p.eq(spi.cs[0]),
eem0[3].n.eq(~spi.cs[0]),
2020-08-20 09:53:39 +08:00
2020-08-23 17:17:09 +08:00
eem0[4].p.eq(spi.cs[1]),
eem0[4].n.eq(~spi.cs[1]),
2020-08-20 09:53:39 +08:00
2020-08-23 17:17:09 +08:00
eem0[5].p.eq(spi.cs[2]),
eem0[5].n.eq(~spi.cs[2]),
2020-08-20 09:53:39 +08:00
2020-08-23 22:28:32 +08:00
eem0[6].p.eq(io_update),
eem0[6].n.eq(~io_update),
2020-08-20 09:53:39 +08:00
led.eq(1)
2020-08-09 02:03:47 +08:00
]
2020-08-21 11:17:08 +08:00
2020-08-09 02:03:47 +08:00
if __name__ == "__main__":
platform = HumpbackPlatform()
platform.build(UrukulConnector(platform))