diff autocal/txlevels.c @ 101:b0618796d28d

fc-rfcal-txband: added safety checks for NaN power measurements and out-of-tolerance final Tx power levels
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 11 Aug 2017 03:20:43 +0000
parents a2d4cab0a592
children 80281b67511f
line wrap: on
line diff
--- a/autocal/txlevels.c	Fri Aug 11 02:45:10 2017 +0000
+++ b/autocal/txlevels.c	Fri Aug 11 03:20:43 2017 +0000
@@ -2,6 +2,7 @@
  * The calibration of Tx power levels is implemented here.
  */
 
+#include <math.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <rvinterf/l1tm.h>
@@ -38,7 +39,8 @@
 calibrate_tx_levels()
 {
 	unsigned plnum, plidx, apc;
-	double target, meas;
+	double target, meas, error;
+	int nanflag = 0, errflag = 0;
 
 	printf("Calibrating Tx power levels\n");
 	printf("Starting RF Tx on the DUT\n");
@@ -54,12 +56,25 @@
 		do_txpw(TX_APC_DAC, apc);
 		usleep(20000);
 		meas = tx_power_meas();
+		if (isnan(meas))
+			nanflag = 1;
+		error = meas - target;
+		if (error < -2.0 || error > 2.0)
+			errflag = 1;
 		printf(
 	"Tx power level #%u: target %.1f dBm, APC=%u, meas %.2f dBm (%+.2f)\n",
-			plnum, target, apc, meas, meas - target);
+			plnum, target, apc, meas, error);
 	}
 
 	printf("Stopping RF Tx on the DUT\n");
 	do_rfe(STOP_ALL);
+	if (nanflag) {
+		printf("Error: got NaN power measurement, aborting\n");
+		exit(ERROR_TARGET);
+	}
+	if (errflag) {
+		printf("Error: Tx power off by more than 2 dBm, aborting\n");
+		exit(ERROR_TARGET);
+	}
 	return(0);
 }