FreeCalypso > hg > fc-rfcal-tools
annotate autocal/txstandchk.c @ 133:c99b1dce04ec default tip
fc-rfcal-txcheck: check and report ramp tolerance
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 20 Dec 2021 04:22:19 +0000 |
parents | 94e8a410d6bd |
children |
rev | line source |
---|---|
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
73
c9bd1f75029f
autocal: C main modules for standalone programs renamed more sensibly
Mychaela Falconia <falcon@freecalypso.org>
parents:
71
diff
changeset
|
2 * fc-rfcal-txcheck is a debug utility implementing just one part |
c9bd1f75029f
autocal: C main modules for standalone programs renamed more sensibly
Mychaela Falconia <falcon@freecalypso.org>
parents:
71
diff
changeset
|
3 * of the fc-rfcal-txband process in a standalone manner; |
c9bd1f75029f
autocal: C main modules for standalone programs renamed more sensibly
Mychaela Falconia <falcon@freecalypso.org>
parents:
71
diff
changeset
|
4 * this module contains the main() function for this standalone utlity. |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
5 */ |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
6 |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
7 #include <stdio.h> |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
8 #include <stdlib.h> |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 #include <string.h> |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 #include <strings.h> |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
11 #include <unistd.h> |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 #include <rvinterf/l1tm.h> |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 #include <rvinterf/exitcodes.h> |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 #include "stdband.h" |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 |
133
c99b1dce04ec
fc-rfcal-txcheck: check and report ramp tolerance
Mychaela Falconia <falcon@freecalypso.org>
parents:
132
diff
changeset
|
16 extern double tx_power_meas(), tx_power_meas_ramp(); |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
17 |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 static struct band { |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 char *name; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 unsigned rfpw_std_band; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 unsigned default_arfcn; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 unsigned start_plnum; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 unsigned end_plnum; |
71
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
24 int spec_max_dbm; |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
25 } bands[] = { |
71
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
26 {"850", RFPW_STD_BAND_850, 190, 5, 19, 33}, |
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
27 {"900", RFPW_STD_BAND_900, 40, 5, 19, 33}, |
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
28 {"1800", RFPW_STD_BAND_1800, 700, 0, 15, 30}, |
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
29 {"1900", RFPW_STD_BAND_1900, 660, 0, 15, 30}, |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 {0, 0, 0} |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 }; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 static struct band *selected_band; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 static unsigned arfcn; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 finish_cmdline(argc, argv) |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 char **argv; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 { |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 extern int optind; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 struct band *band; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 if (argc - optind < 1 || argc - optind > 2) { |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 fprintf(stderr, "usage: %s band [arfcn]\n", argv[0]); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
43 exit(ERROR_USAGE); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
44 } |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
45 for (band = bands; band->name; band++) |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
46 if (!strcmp(band->name, argv[optind])) |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
47 break; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
48 if (!band->name) { |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
49 fprintf(stderr, "error: \"%s\" is not a known band\n", |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
50 argv[optind]); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
51 exit(ERROR_USAGE); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
52 } |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
53 selected_band = band; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
54 if (argv[optind+1]) |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
55 arfcn = atoi(argv[optind+1]); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
56 else |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
57 arfcn = band->default_arfcn; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
58 return(0); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
59 } |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
60 |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
61 main(argc, argv) |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
62 char **argv; |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
63 { |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
64 unsigned plnum; |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
65 double meas; |
71
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
66 int spec_dbm; |
133
c99b1dce04ec
fc-rfcal-txcheck: check and report ramp tolerance
Mychaela Falconia <falcon@freecalypso.org>
parents:
132
diff
changeset
|
67 char *ramp_status; |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
68 |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
69 socket_pathname_options(argc, argv); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
70 finish_cmdline(argc, argv); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
71 connect_rvinterf_socket(); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
72 connect_tsid_socket(); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
73 setlinebuf(stdout); /* to allow logging with tee */ |
55
b313884c79fd
autocal Tx: txpwr-cal-setup factored out of fc-rfcal-txcheck
Mychaela Falconia <falcon@freecalypso.org>
parents:
54
diff
changeset
|
74 printf("Preparing RF test system for %s MHz Tx calibration\n", |
b313884c79fd
autocal Tx: txpwr-cal-setup factored out of fc-rfcal-txcheck
Mychaela Falconia <falcon@freecalypso.org>
parents:
54
diff
changeset
|
75 selected_band->name); |
b313884c79fd
autocal Tx: txpwr-cal-setup factored out of fc-rfcal-txcheck
Mychaela Falconia <falcon@freecalypso.org>
parents:
54
diff
changeset
|
76 do_txpwr_cal_setup(selected_band->name, arfcn); |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
77 |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
78 printf("Putting the DUT into Test Mode\n"); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
79 do_tms(1); |
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
80 do_rfpw(STD_BAND_FLAG, selected_band->rfpw_std_band); |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
81 do_rfpw(TCH_ARFCN, arfcn); |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
82 do_rfpw(AFC_ENA_FLAG, 0); |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
83 printf("Starting RF Tx on the DUT\n"); |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
84 do_rfe(RX_TX_TCH); |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
85 |
71
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
86 spec_dbm = selected_band->spec_max_dbm; |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
87 for (plnum = selected_band->start_plnum; |
71
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
88 plnum <= selected_band->end_plnum; plnum++, spec_dbm -= 2) { |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
89 do_txpw(TX_PWR_LEVEL, plnum); |
132
94e8a410d6bd
fc-rfcal-txcheck: pass PCL to tester (txpwr-cal-pcl)
Mychaela Falconia <falcon@freecalypso.org>
parents:
73
diff
changeset
|
90 pass_pcl_to_tester(plnum); |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
91 usleep(20000); |
133
c99b1dce04ec
fc-rfcal-txcheck: check and report ramp tolerance
Mychaela Falconia <falcon@freecalypso.org>
parents:
132
diff
changeset
|
92 meas = tx_power_meas_ramp(&ramp_status); |
71
784ce9f3a80a
fc-rfcal-txcheck: spec and error values added to the output
Mychaela Falconia <falcon@freecalypso.org>
parents:
55
diff
changeset
|
93 printf( |
133
c99b1dce04ec
fc-rfcal-txcheck: check and report ramp tolerance
Mychaela Falconia <falcon@freecalypso.org>
parents:
132
diff
changeset
|
94 "Tx power level #%u: spec %d dBm, meas %.2f dBm (%+.2f), ramp %s\n", |
c99b1dce04ec
fc-rfcal-txcheck: check and report ramp tolerance
Mychaela Falconia <falcon@freecalypso.org>
parents:
132
diff
changeset
|
95 plnum, spec_dbm, meas, meas - spec_dbm, ramp_status); |
54
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
96 } |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
97 |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
98 printf("Stopping RF Tx on the DUT\n"); |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
99 do_rfe(STOP_ALL); |
21f6dba5c4df
fc-rfcal-txcheck ready to test
Mychaela Falconia <falcon@freecalypso.org>
parents:
53
diff
changeset
|
100 exit(0); |
53
bc2397f62bdb
rf-cal-txcheck started
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
101 } |