aboutsummaryrefslogtreecommitdiff
path: root/nmigen_boards/kc705.py
diff options
context:
space:
mode:
authorSebastien Bourdeauducq <sb@m-labs.hk>2019-07-03 17:42:48 +0800
committerSebastien Bourdeauducq <sb@m-labs.hk>2019-07-03 17:42:48 +0800
commit0bcb6099ce4a996931643113a512468efc59bf19 (patch)
treea34c143ecdbb2e0bad4ac6b02d55e7facbaf0836 /nmigen_boards/kc705.py
parentbb3d6d742fb759ecf51d303942b5570f66407a6e (diff)
add KC705
Diffstat (limited to 'nmigen_boards/kc705.py')
-rw-r--r--nmigen_boards/kc705.py45
1 files changed, 45 insertions, 0 deletions
diff --git a/nmigen_boards/kc705.py b/nmigen_boards/kc705.py
new file mode 100644
index 0000000..2f3385e
--- /dev/null
+++ b/nmigen_boards/kc705.py
@@ -0,0 +1,45 @@
+import os
+import subprocess
+
+from nmigen.build import *
+from nmigen.vendor.xilinx_7series import *
+from .dev import *
+
+
+__all__ = ["KC705Platform"]
+
+
+class KC705Platform(Xilinx7SeriesPlatform):
+ device = "xc7k325t"
+ package = "ffg900"
+ speed = "2"
+ resources = [
+ Resource("clk156", 0, DiffPairs("K28", "K29", dir="i"),
+ Clock(156e6), Attrs(IOSTANDARD="LVDS_25")),
+
+ Resource("user_led", 0, Pins("AB8", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 1, Pins("AA8", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 2, Pins("AC9", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 3, Pins("AB9", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 4, Pins("AE26", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 5, Pins("G19", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 6, Pins("E18", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+ Resource("user_led", 7, Pins("F16", dir="o"), Attrs(IOSTANDARD="LVCMOS15")),
+
+ UARTResource(0,
+ rx="M19", tx="K24",
+ attrs=Attrs(IOSTANDARD="LVCMOS33")
+ ),
+ ]
+ connectors = []
+
+ def toolchain_program(self, products, name):
+ openocd = os.environ.get("OPENOCD", "openocd")
+ with products.extract("{}.bit".format(name)) as bitstream_filename:
+ subprocess.run([openocd, "-c",
+ "source [find board/kc705.cfg]; init; pld load 0 bitstream_filename; exit".format(bitstream_filename)], check=True)
+
+
+if __name__ == "__main__":
+ from ._blinky import build_and_program
+ build_and_program(KC705Platform, "clk156")