aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-07-27 14:28:31 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:04:00 -0800
commit39bd5b1bad753c3634f09f023c37feb557924d51 (patch)
treed997258283c28ea27d2e455ee1d58d63c5b88d0f /mpm/python
parent3ea3d8a33876ad4776b069a234c7becfa943852f (diff)
downloaduhd-39bd5b1bad753c3634f09f023c37feb557924d51.tar.gz
uhd-39bd5b1bad753c3634f09f023c37feb557924d51.tar.bz2
uhd-39bd5b1bad753c3634f09f023c37feb557924d51.zip
mpm: Minor fixes to aurora_control
- Slaves are properly initialized/deinitialized - Return values from BISTs return more info - Minor formatting fixes
Diffstat (limited to 'mpm/python')
-rw-r--r--mpm/python/usrp_mpm/aurora_control.py23
1 files changed, 15 insertions, 8 deletions
diff --git a/mpm/python/usrp_mpm/aurora_control.py b/mpm/python/usrp_mpm/aurora_control.py
index 1174a2d0d..b676e99d1 100644
--- a/mpm/python/usrp_mpm/aurora_control.py
+++ b/mpm/python/usrp_mpm/aurora_control.py
@@ -237,7 +237,7 @@ class AuroraControl(object):
'Running Latency Loopback BIST at %.0fMB/s for %.0fs...',
coerced_rate/8e6, duration
)
- self._pre_test_init()
+ self._pre_test_init(slave)
start_time = time.time()
results = {
'latencies': [],
@@ -299,7 +299,7 @@ class AuroraControl(object):
if slave is not None:
results['sla_overruns'], results['sla_hard_errors'] = \
self._get_slave_status(slave)
- self._post_test_cleanup()
+ self._post_test_cleanup(slave)
return results
def run_ber_loopback_bist(self, duration, requested_rate, slave=None):
@@ -314,7 +314,7 @@ class AuroraControl(object):
self.log.info('Running BER Loopback BIST at {}MB/s for {}s...'.format(
coerced_rate/8e6, duration
))
- self._pre_test_init()
+ self._pre_test_init(slave)
mst_overruns = 0
self.log.info("Starting BER test...")
start_time = time.time()
@@ -352,18 +352,25 @@ class AuroraControl(object):
results['sla_overruns'], results['sla_hard_errors'] = \
self._get_slave_status(slave)
if results['mst_samps'] != 0:
- mst_latency_us = self._mst_status_to_latency_us(mst_status)
+ results['mst_latency_us'] = \
+ self._mst_status_to_latency_us(mst_status)
self.log.info('BIST Complete!')
self.log.info('- Elapsed Time = {:.2} s'.format(
results['time_elapsed']
))
+ results['max_ber'] = \
+ float(results['mst_errors']+1) / results['mst_samps']
+ results['approx_throughput'] = \
+ (8 * results['mst_samps']) / results['time_elapsed']
self.log.info('- Max BER (Bit Error Ratio) = %.4g ' \
'(%d errors out of %d)',
- float(results['mst_errors']+1) / results['mst_samps'],
- results['mst_errors'], results['mst_samps'])
- self.log.info('- Max Roundtrip Latency = %.1fus'%mst_latency_us)
+ results['max_ber'],
+ results['mst_errors'],
+ results['mst_samps'])
+ self.log.info('- Max Roundtrip Latency = %.1fus',
+ results['mst_latency_us'])
self.log.info('- Approx Throughput = %.0fMB/s',
- (8e-6*results['mst_samps'])/results['time_elapsed'])
+ results['approx_throughput'] / 1e6)
else:
self.log.error('No samples received -- BIST Failed!')
self._post_test_cleanup(slave)