1
0
forked from M-Labs/artiq

test: relax test_dma_playback_time on Zynq

This commit is contained in:
Sebastien Bourdeauducq 2020-09-11 11:21:45 +08:00
parent 6195b1d3a0
commit bff611a888

View File

@ -627,11 +627,13 @@ class _DMA(EnvExperiment):
self.delta = now_mu() - start self.delta = now_mu() - start
@kernel @kernel
def playback_many(self, n): def playback_many(self, n, add_delay=False):
handle = self.core_dma.get_handle(self.trace_name) handle = self.core_dma.get_handle(self.trace_name)
self.core.break_realtime() self.core.break_realtime()
t1 = self.core.get_rtio_counter_mu() t1 = self.core.get_rtio_counter_mu()
for i in range(n): for i in range(n):
if add_delay:
delay(2*us)
self.core_dma.playback_handle(handle) self.core_dma.playback_handle(handle)
t2 = self.core.get_rtio_counter_mu() t2 = self.core.get_rtio_counter_mu()
self.set_dataset("dma_playback_time", self.core.mu_to_seconds(t2 - t1)) self.set_dataset("dma_playback_time", self.core.mu_to_seconds(t2 - t1))
@ -724,12 +726,17 @@ class DMATest(ExperimentCase):
self.device_mgr.get_desc("ad9914dds0") self.device_mgr.get_desc("ad9914dds0")
except KeyError: except KeyError:
raise unittest.SkipTest("skipped on Kasli for now") raise unittest.SkipTest("skipped on Kasli for now")
exp = self.create(_DMA) exp = self.create(_DMA)
is_zynq = exp.core.target_cls == CortexA9Target
count = 20000 count = 20000
exp.record_many(40) exp.record_many(40)
exp.playback_many(count) exp.playback_many(count, is_zynq)
dt = self.dataset_mgr.get("dma_playback_time") dt = self.dataset_mgr.get("dma_playback_time")
print("dt={}, dt/count={}".format(dt, dt/count)) print("dt={}, dt/count={}".format(dt, dt/count))
if is_zynq:
self.assertLess(dt/count, 6.2*us)
else:
self.assertLess(dt/count, 4.5*us) self.assertLess(dt/count, 4.5*us)
def test_dma_underflow(self): def test_dma_underflow(self):