FreeCalypso > hg > fc-rfcal-tools
diff autocal/txbandmain.c @ 75:93653fe9b4ef
fc-rfcal-txband started
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 15 Jul 2017 19:22:30 +0000 |
parents | |
children | 5c3574f8c8c1 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/autocal/txbandmain.c Sat Jul 15 19:22:30 2017 +0000 @@ -0,0 +1,117 @@ +/* + * This module contains the main() function for fc-rfcal-txband. + */ + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <strings.h> +#include <unistd.h> +#include <rvinterf/l1tm.h> +#include <rvinterf/exitcodes.h> +#include "txband.h" +#include "stdband.h" + +struct tx_calchan_range tx_calchan_850[] = { + {128, 134, 131}, + {135, 150, 143}, + {151, 166, 159}, + {167, 182, 175}, + {183, 197, 190}, + {198, 213, 206}, + {214, 229, 222}, + {230, 251, 241} +}; + +struct tx_calchan_range tx_calchan_900[] = { + { 0, 27, 14}, + { 28, 47, 40}, + { 48, 66, 57}, + { 67, 85, 76}, + { 86, 104, 95}, + { 105, 124, 114}, + { 975, 994, 985}, + { 995, 1023, 1009} +}; + +struct tx_calchan_range tx_calchan_1800[] = { + {512, 553, 533}, + {554, 594, 574}, + {595, 636, 615}, + {637, 677, 657}, + {678, 720, 700}, + {721, 760, 740}, + {761, 802, 781}, + {803, 885, 844} +}; + +struct tx_calchan_range tx_calchan_1900[] = { + {512, 549, 531}, + {550, 586, 568}, + {587, 623, 605}, + {624, 697, 660}, + {698, 726, 712}, + {727, 754, 740}, + {755, 782, 768}, + {783, 810, 796} +}; + +struct txcal_band txcal_band_list[] = { + {"850", RFPW_STD_BAND_850, 190, 5, 19, tx_calchan_850, 4}, + {"900", RFPW_STD_BAND_900, 40, 5, 19, tx_calchan_900, 1}, + {"1800", RFPW_STD_BAND_1800, 700, 0, 15, tx_calchan_1800, 4}, + {"1900", RFPW_STD_BAND_1900, 660, 0, 15, tx_calchan_1900, 3}, + {0, 0, 0, 0, 0, 0, 0} +}; + +struct txcal_band *txcal_band; +char *txlevels_profile; + +struct tx_basis_point tx_basis[MAX_BASIS_POINTS]; +unsigned num_basis_points; + +struct tx_level tx_levels[MAX_TX_LEVELS]; + +finish_cmdline(argc, argv) + char **argv; +{ + extern int optind; + struct txcal_band *band; + + if (argc - optind != 2) { + fprintf(stderr, "usage: %s band txlevels-profile\n", argv[0]); + exit(ERROR_USAGE); + } + for (band = txcal_band_list; band->name; band++) + if (!strcmp(band->name, argv[optind])) + break; + if (!band->name) { + fprintf(stderr, "error: \"%s\" is not a known band\n", + argv[optind]); + exit(ERROR_USAGE); + } + txcal_band = band; + txlevels_profile = argv[optind+1]; + return(0); +} + +main(argc, argv) + char **argv; +{ + socket_pathname_options(argc, argv); + finish_cmdline(argc, argv); + connect_rvinterf_socket(); + connect_tsid_socket(); + setlinebuf(stdout); /* to allow logging with tee */ + printf("Preparing RF test system for %s MHz Tx calibration\n", + txcal_band->name); + do_txpwr_cal_setup(txcal_band->name, txcal_band->main_arfcn); + + printf("Putting the DUT into Test Mode\n"); + do_tms(1); + do_rfpw(STD_BAND_FLAG, txcal_band->rfpw_std_band); + do_rfpw(TCH_ARFCN, txcal_band->main_arfcn); + do_rfpw(AFC_ENA_FLAG, 0); + + +}