FreeCalypso > hg > fc-rfcal-tools
changeset 98:615df2fb1ec3
doc/Tx-cal-theory: update with both theory and practice
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 17 Jul 2017 22:49:35 +0000 (2017-07-17) |
parents | 037d9200aae4 |
children | b06532c9642f |
files | doc/Tx-cal-theory |
diffstat | 1 files changed, 101 insertions(+), 15 deletions(-) [+] |
line wrap: on
line diff
--- a/doc/Tx-cal-theory Mon Jul 17 19:15:44 2017 +0000 +++ b/doc/Tx-cal-theory Mon Jul 17 22:49:35 2017 +0000 @@ -48,23 +48,109 @@ calibration basis run (because slot 0 is a valid power level for these bands), but an artifact remains in the levels.900 table in the unused slot 0. -In the present FreeCalypso RF calibration tools suite the planned -fc-rfcal-txband program that will perform the entire Tx band calibration -procedure has not been written yet. Instead we have the following two building -blocks: +Target power level numbers +========================== + +Ideally the power level numbers to be used as the targets for the calibration +process would be the levels given in the GSM 05.05 spec: from 33 dBm down to +5 dBm for the EGSM and GSM850 bands or from 30 dBm down to 0 dBm for DCS and +PCS, in 2 dBm steps in each case. However, the evidence from TI's calibration +documents (both Sara and LoCosto) is that some devices are not able to produce +the very highest and sometimes the very lowest power levels given in the spec, +and getting a successful calibration requires setting the calibration targets +to slightly shifted numbers, although still within the tolerances allowed by +the GSM 05.05 spec. The table in TI's Sara calibration document (page 26) has +the highest power level reduced by 1.2 relative to the spec, the next highest +by 0.5, whereas the lowest 4 (EGSM) or 6 (DCS) levels are raised and compacted +together. The table in the LoCosto document (page 44) has the highest power +level for each band reduced by 0.8, making it 32.2 dBm for EGSM and GSM850 and +29.2 dBm for DCS and PCS, while all other levels are set to the spec numbers. + +In my own experience with getting the Tx power levels calibrated on our current +FCDEV3B boards, our hardware is able to hit all of the lowest spec power levels +with good margin (the APC DAC value never goes below the 60-70 range), hence +the low targets did not need to be shifted, but the highest spec power level +could not be achieved in every band. Following TI's practice with LoCosto, I +set the highest power level target to 32.2 dBm for the EGSM band and to 29.2 dBm +for PCS, but I was consistently able to get the full 30 dBm out in the DCS band, +hence I set the DCS band highest power level target to the official number of +30 dBm. It needs to be emphasized, however, that these results are quite +specific to our current flock of FCDEV3B hardware, and your results will most +likely be different if you are working with a different hw design such as a +non-FreeCalypso derivative of Openmoko's GTA02 design. + +Profiles for Tx levels calibration +================================== + +Our fc-rfcal-txband program that performs the actual per-unit calibration of Tx +power levels for each band requires a preconfigured txlevels calibration profile +for each band as one of its inputs; if you are performing calibration on +individual units of a board design for which the correct profiles have already +been crafted, you simply use those given profiles (fcom1 for our current flock +of FCDEV3B boards), but if you are doing Tx power level calibration on a new +board design for the first time, you first need to characterize the Tx output +level behaviour of your new board design and craft the appropriate set of +profiles. -fc-rfcal-txbasis performs the preliminary "basis" step of Tx power level -calibration: it sets the APC DAC to each of the values given on the command line -in turn, and reports the resulting output power level in dBm. The temporary -APC DAC values do get written into the Tx levels table in L1 (there is no other -way to set the APC DAC value for the active transmitter through Test Mode), but -the MISC_ENABLE command to save Tx calibration tables in FFS is NOT issued, -thus the corruption of the Tx levels table inflicted by this program will get -blown away on the next rfpw 7 (Test Mode band selection) command. +The profiles for txlevels calibration reside in /opt/freecalypso/rfcal/txlevels; +each per-band profile is sought in a file named profile_name-band_number, where +profile_name is the profile name argument given to fc-rfcal-txband and +band_number is one of 850, 900, 1800 or 1900. For example, the profile set for +our current FCDEV3B hardware is named fcom1 ("FreeCalypso hardware, Openmoko- +based, version 1"), this hw platform is 900/1800/1900 MHz triband, and the +individual profile config files are fcom1-900, fcom1-1800 and fcom1-1900. + +Each profile provides two key pieces of data: the list of fixed APC DAC values +to be used as the basis set for constructing the piecewise linear model, and +the list of power levels in dBm that will be the targets for the calibration. + +Crafting the txlevels calibration profiles for a new board design +================================================================= + +If you are working with a new (or new-to-you) board design with no previous Tx +levels calibration experience, you need to begin by characterizing its Tx +output level behaviour so you can determine what APC values are appropriate for +the basis set, whether or not you need to shift the highest and/or lowest +target levels from their nominal spec values, and if some target shifting is +needed, which levels need to be shifted and by how much. + +The tool you will need for this investigation is fc-rfcal-txbasis. It requires +fc-cmu200d and rvinterf to be running, talking to the CMU200 and to the DUT, +respectively, and it takes the band number (850/900/1800/1900) and a set of +APC DAC values on the command line; no pre-existing txlevels profile is needed. +It commands the DUT to transmit at each of the specified APC DAC values in turn +and reports the power output levels measured by the CMU200. + +VERY IMPORTANT: You need to be very sure that your CMU200 or other measuring +instrument is itself in good calibration standing, i.e., that the measurements +it reports are trustworthy, and that the insertion loss in your cabling setup +(all the way from the actual DUT's antenna connector or RF test port to your +CMU200) really matches the numbers you have put in your cable configuration file +(see Cable-config-howto). If you fail to ensure these prerequisites, your +fc-rfcal-txbasis observations will be meaningless, as the cable insertion losses +are typically of the same order of magnitude as the transmitter differences you +are trying to determine. + +You will need to run fc-rfcal-txbasis with a guesstimated set of APC DAC values, +to be revised iteratively, and get a feel for what your DUT is putting out. +Are you able to hit the lowest spec power level consistently while the APC DAC +value remains well above zero? Are you able to hit the highest spec power level +as well, or does the measured power output fall short of this target no matter +how high you crank the APC DAC? These observations will tell you whether or not +you need to shift the highest and/or lowest target power levels in your new +txlevels calibration profile. + +Regular calibration runs +======================== + +Once you have a good set of profiles for the type of Calypso GSM device you are +calibrating, just run fc-rfcal-txband with the band number and the name of your +profile. + +Checking existing calibration +============================= fc-rfcal-txcheck is a completely non-invasive program (does not make any writes to any L1 RF tables or to FFS) that steps through all power levels for the specified band (5-19 for EGSM or GSM850, or 0-15 for DCS or PCS), performs a -power measurement at each level, and displays the measured result. An -equivalent operation will be the finishing sanity check step in the full Tx -power level calibration program. +power measurement at each level, and displays the measured result.