2016-01-26 06:49:08 +08:00
|
|
|
from artiq.experiment import *
|
2017-02-27 18:37:30 +08:00
|
|
|
from artiq.coredevice.comm_analyzer import (decode_dump, StoppedMessage,
|
|
|
|
OutputMessage, InputMessage,
|
2017-02-27 19:19:46 +08:00
|
|
|
_extract_log_chars, get_analyzer_dump)
|
2015-12-24 19:25:29 +08:00
|
|
|
from artiq.test.hardware_testbench import ExperimentCase
|
|
|
|
|
|
|
|
|
|
|
|
class CreateTTLPulse(EnvExperiment):
|
|
|
|
def build(self):
|
|
|
|
self.setattr_device("core")
|
2016-02-25 02:12:12 +08:00
|
|
|
self.setattr_device("loop_in")
|
|
|
|
self.setattr_device("loop_out")
|
2015-12-24 19:25:29 +08:00
|
|
|
|
|
|
|
@kernel
|
2016-04-15 01:18:36 +08:00
|
|
|
def initialize_io(self):
|
2016-06-29 02:37:39 +08:00
|
|
|
self.core.reset()
|
2016-04-12 18:17:06 +08:00
|
|
|
self.loop_in.input()
|
2016-04-14 22:57:16 +08:00
|
|
|
self.loop_out.off()
|
2016-04-15 01:18:36 +08:00
|
|
|
|
|
|
|
@kernel
|
|
|
|
def run(self):
|
|
|
|
self.core.break_realtime()
|
2016-02-23 15:48:12 +08:00
|
|
|
with parallel:
|
2015-12-26 21:10:19 +08:00
|
|
|
with sequential:
|
|
|
|
delay_mu(100)
|
2016-02-25 02:12:12 +08:00
|
|
|
self.loop_out.pulse_mu(1000)
|
2018-07-23 22:34:18 +08:00
|
|
|
self.loop_in.count(self.loop_in.gate_both_mu(1200))
|
2015-12-24 19:25:29 +08:00
|
|
|
|
|
|
|
|
2016-06-07 19:26:49 +08:00
|
|
|
class WriteLog(EnvExperiment):
|
|
|
|
def build(self):
|
|
|
|
self.setattr_device("core")
|
|
|
|
|
|
|
|
@kernel
|
|
|
|
def run(self):
|
2016-06-29 02:37:39 +08:00
|
|
|
self.core.reset()
|
2016-06-07 19:26:49 +08:00
|
|
|
rtio_log("foo", 32)
|
|
|
|
|
|
|
|
|
2015-12-24 19:25:29 +08:00
|
|
|
class AnalyzerTest(ExperimentCase):
|
|
|
|
def test_ttl_pulse(self):
|
2017-05-22 15:45:45 +08:00
|
|
|
core_host = self.device_mgr.get_desc("core")["arguments"]["host"]
|
2015-12-24 19:25:29 +08:00
|
|
|
|
|
|
|
exp = self.create(CreateTTLPulse)
|
2016-04-15 01:18:36 +08:00
|
|
|
exp.initialize_io()
|
2017-02-27 19:19:46 +08:00
|
|
|
get_analyzer_dump(core_host) # clear analyzer buffer
|
2015-12-24 19:25:29 +08:00
|
|
|
exp.run()
|
|
|
|
|
2017-02-27 19:19:46 +08:00
|
|
|
dump = decode_dump(get_analyzer_dump(core_host))
|
2016-03-15 21:44:56 +08:00
|
|
|
self.assertIsInstance(dump.messages[-1], StoppedMessage)
|
2015-12-26 21:10:19 +08:00
|
|
|
output_messages = [msg for msg in dump.messages
|
|
|
|
if isinstance(msg, OutputMessage)
|
|
|
|
and msg.address == 0]
|
|
|
|
self.assertEqual(len(output_messages), 2)
|
2015-12-24 19:26:24 +08:00
|
|
|
self.assertEqual(
|
2015-12-26 21:10:19 +08:00
|
|
|
abs(output_messages[0].timestamp - output_messages[1].timestamp),
|
2015-12-24 19:26:24 +08:00
|
|
|
1000)
|
2015-12-26 21:10:19 +08:00
|
|
|
input_messages = [msg for msg in dump.messages
|
|
|
|
if isinstance(msg, InputMessage)]
|
|
|
|
self.assertEqual(len(input_messages), 2)
|
2018-08-17 13:35:16 +08:00
|
|
|
# on Kasli systems, this has to go through the isolated DIO card
|
2015-12-26 21:10:19 +08:00
|
|
|
self.assertAlmostEqual(
|
|
|
|
abs(input_messages[0].timestamp - input_messages[1].timestamp),
|
2018-08-17 13:35:16 +08:00
|
|
|
1000, delta=4)
|
2016-06-07 19:26:49 +08:00
|
|
|
|
|
|
|
def test_rtio_log(self):
|
2017-05-22 15:45:45 +08:00
|
|
|
core_host = self.device_mgr.get_desc("core")["arguments"]["host"]
|
2016-06-07 19:26:49 +08:00
|
|
|
|
|
|
|
exp = self.create(WriteLog)
|
2017-02-27 19:19:46 +08:00
|
|
|
get_analyzer_dump(core_host) # clear analyzer buffer
|
2016-06-07 19:26:49 +08:00
|
|
|
exp.run()
|
|
|
|
|
2017-02-27 19:19:46 +08:00
|
|
|
dump = decode_dump(get_analyzer_dump(core_host))
|
2016-06-07 19:26:49 +08:00
|
|
|
log = "".join([_extract_log_chars(msg.data)
|
|
|
|
for msg in dump.messages
|
|
|
|
if isinstance(msg, OutputMessage) and msg.channel == dump.log_channel])
|
2017-11-03 00:52:53 +08:00
|
|
|
self.assertEqual(log, "foo\x1E32\x1D")
|