1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
from nmigen.build import *
__all__ = [
"LEDResources", "RGBLEDResource", "ButtonResources", "SwitchResources",
"Display7SegResource",
]
def _SplitResources(*args, pins, invert=False, attrs=None, default_name, dir):
assert isinstance(pins, (str, list, dict))
if isinstance(pins, str):
pins = pins.split()
if isinstance(pins, list):
pins = dict(enumerate(pins))
resources = []
for number, pin in pins.items():
ios = [Pins(pin, dir=dir, invert=invert)]
if attrs is not None:
ios.append(attrs)
resources.append(Resource.family(*args, number, default_name=default_name, ios=ios))
return resources
def LEDResources(*args, **kwargs):
return _SplitResources(*args, **kwargs, default_name="led", dir="o")
def RGBLEDResource(*args, r, g, b, invert=False, attrs=None):
ios = []
ios.append(Subsignal("r", Pins(r, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("g", Pins(g, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("b", Pins(b, dir="o", invert=invert, assert_width=1)))
if attrs is not None:
ios.append(attrs)
return Resource.family(*args, default_name="rgb_led", ios=ios)
def ButtonResources(*args, **kwargs):
return _SplitResources(*args, **kwargs, default_name="button", dir="i")
def SwitchResources(*args, **kwargs):
return _SplitResources(*args, **kwargs, default_name="switch", dir="i")
def Display7SegResource(*args, a, b, c, d, e, f, g, dp=None, invert=False, attrs=None):
ios = []
ios.append(Subsignal("a", Pins(a, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("b", Pins(b, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("c", Pins(c, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("d", Pins(d, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("e", Pins(e, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("f", Pins(f, dir="o", invert=invert, assert_width=1)))
ios.append(Subsignal("g", Pins(g, dir="o", invert=invert, assert_width=1)))
if dp is not None:
ios.append(Subsignal("dp", Pins(dp, dir="o", assert_width=1)))
if attrs is not None:
ios.append(attrs)
return Resource.family(*args, default_name="display_7seg", ios=ios)
|