-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdemo_artiq_ttl_rx.py
executable file
·76 lines (64 loc) · 2.46 KB
/
demo_artiq_ttl_rx.py
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#!/usr/bin/env python3.5
from migen import *
from migen.build.platforms import kc705
from misoc.cores.uart import RS232PHY
from gtx import GTXReceiver
from ttl_xm105 import ttl_extension
from sequencer import Sequencer
from i2c import I2CMaster
from si5324_kc705 import get_i2c_program, Si5324ClockRouter
class ARTIQTTLRX(Module):
def __init__(self, platform):
platform.add_extension(ttl_extension)
sys_clock_pads = platform.request("clk156")
self.clock_domains.cd_sys = ClockDomain(reset_less=True)
self.specials += Instance("IBUFGDS",
i_I=sys_clock_pads.p, i_IB=sys_clock_pads.n,
o_O=self.cd_sys.clk)
sys_clk_freq = 156000000
self.comb += platform.request("sfp_tx_disable_n").eq(1)
gtx = GTXReceiver(
clock_pads=platform.request("sgmii_clock"),
rx_pads=platform.request("sfp_rx"),
sys_clk_freq=sys_clk_freq)
self.submodules += gtx
# clean up GTX clock using Si5324
i2c_master = I2CMaster(platform.request("i2c"))
sequencer = Sequencer(get_i2c_program(sys_clk_freq))
si5324_clock_router = Si5324ClockRouter(platform, sys_clk_freq)
self.submodules += i2c_master, sequencer, si5324_clock_router
self.comb += sequencer.bus.connect(i2c_master.bus)
# decode frames
back_buffer = Signal(32)
front_buffer = Signal(32)
frame_hi = Signal()
self.sync.rx_clean += [
If(gtx.decoders[0].k,
front_buffer.eq(back_buffer),
frame_hi.eq(0)
).Else(
If(frame_hi,
back_buffer[16:].eq(
Cat(gtx.decoders[0].d, gtx.decoders[1].d))
).Else(
back_buffer[:16].eq(
Cat(gtx.decoders[0].d, gtx.decoders[1].d))
),
frame_hi.eq(1)
)
]
# drive TTLs
self.comb += [
platform.request("user_sma_gpio_p").eq(front_buffer[0]),
platform.request("user_sma_gpio_n").eq(front_buffer[1])
]
for i in range(8):
self.comb += platform.request("user_led").eq(front_buffer[2+i])
for i in range(22):
self.comb += platform.request("ttl").eq(front_buffer[10+i])
def main():
platform = kc705.Platform()
top = ARTIQTTLRX(platform)
platform.build(top, build_dir="artiq_ttl_rx")
if __name__ == "__main__":
main()