FreeCalypso > hg > freecalypso-reveng
view pirelli/rssi @ 371:c7514c8b5b41
pirelli/headset: plug insertion detection figured out
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 14 Jun 2021 01:33:48 +0000 |
parents | a7707c174510 |
children |
line wrap: on
line source
I have been wondering for a long time now how the RSSI bars displayed in end user phone UIs correspond to actual Rx signal levels; Pirelli's RSSI icon on the left side of the home screen can go up to 6 bars, but it was not clear at all what these bars actually correspond to. I just did an experiment to shed some light on this issue: I took a decased Pirelli motherboard and connected it to our CMU200 instrument via the RF test port which Pirelli's mobo has like most phones. Pirelli's RF test port is of the Murata SWD/SWF type, same as Openmoko GTA0x and Motorola C139, and we have a test probe for these ports with precisely known insertion loss numbers, thus combined with the properly calibrated CMU200 instrument and our "main" SMA cable for which we also have precisely known insertion loss numbers (it is the setup we use to calibrate our FCDEV3B modem boards), it is a very trustworthy setup. I varied the downlink signal level put out by the CMU200 and observed the bars displayed by Pirelli's fw on the home screen, and this is what I got: transition from 5 to 6 bars at -75 dBm transition from 6 to 5 bars at -80 dBm transition from 4 to 5 bars at -85 dBm transition from 5 to 4 bars at -90 dBm transition from 3 to 4 bars at -92 dBm transition from 4 to 3 bars at -97 dBm transition from 2 to 3 bars at -97 dBm transition from 3 to 2 bars at -102 dBm transition from 1 to 2 bars at -104 dBm transition from 2 to 1 bars at -105 dBm at -110 dBm it is marginal: sometimes 1 bar, sometimes 0 bars, sometimes no srvc Looking at TI's reference firmware which Pirelli's fw must be based on, the Rx signal strength is passed from L1 to the G23M PS in the form of RxLev numbers that go into GSM 05.08 measurement reports (the standard [0,63] range with 0 corresponding to -110 dBm), ALR does no transformation, and RR passes these RxLev numbers to the Rx driver in the Condat drivers layer, which then converts them to the "bars" numbers for the UI. Pirelli's fw most likely retains this architecture, and their modified version of the Rx driver appears to have the following thresholds or somewhere around there: RxLev >= 35: 6 bars RxLev >= 25: 5 bars RxLev >= 15: 4 bars RxLev >= 10: 3 bars RxLev >= 5 or maybe 6: 2 bars RxLev abysmally low: 1 bar The 5 dB hysteresis seen in my CMU200 experiment is probably caused by the RSSI_MIN_DIFFERENCE logic seen in rr_csf.c in our TCS3-sourced version.