aboutsummaryrefslogtreecommitdiff
path: root/nmigen_boards/dev
diff options
context:
space:
mode:
Diffstat (limited to 'nmigen_boards/dev')
-rw-r--r--nmigen_boards/dev/__init__.py1
-rw-r--r--nmigen_boards/dev/uart.py26
2 files changed, 27 insertions, 0 deletions
diff --git a/nmigen_boards/dev/__init__.py b/nmigen_boards/dev/__init__.py
index b27acfa..f89e46a 100644
--- a/nmigen_boards/dev/__init__.py
+++ b/nmigen_boards/dev/__init__.py
@@ -1 +1,2 @@
+from .uart import UARTResource
from .flash import SPIFlashResources
diff --git a/nmigen_boards/dev/uart.py b/nmigen_boards/dev/uart.py
new file mode 100644
index 0000000..27d1c81
--- /dev/null
+++ b/nmigen_boards/dev/uart.py
@@ -0,0 +1,26 @@
+from nmigen.build import *
+
+
+__all__ = ["UARTResource"]
+
+
+def UARTResource(number, *, rx, tx, rts=None, cts=None, dtr=None, dsr=None, dcd=None, ri=None,
+ attrs=None):
+ io = []
+ io.append(Subsignal("rx", Pins(rx, dir="i")))
+ io.append(Subsignal("tx", Pins(rx, dir="o")))
+ if rts is not None:
+ io.append(Subsignal("rts", Pins(rts, dir="o")))
+ if cts is not None:
+ io.append(Subsignal("cts", Pins(cts, dir="i")))
+ if dtr is not None:
+ io.append(Subsignal("dtr", Pins(dtr, dir="o")))
+ if dsr is not None:
+ io.append(Subsignal("dsr", Pins(dsr, dir="i")))
+ if dcd is not None:
+ io.append(Subsignal("dcd", Pins(dcd, dir="i")))
+ if ri is not None:
+ io.append(Subsignal("ri", Pins(ri, dir="i")))
+ if attrs is not None:
+ io.append(attrs)
+ return Resource("uart", number, *io)