(05-24-2021, 10:21 AM)vortex Wrote: So, I forced the modem into 2G mode (weaker 2G reception where I am at than 4G), took a landline at the same location, setup the call, and recorded the sound with the Sound Recorder app installed by default on Mobian. To make the signal worse and increase the transmit power, I held the phone in a metal enclosure with the door slightly ajar so I could hold it and see it (the kind of metal enclosure circuit breakers are put in).
If possible, it would be interesting to repeat the same experiment once more, now with a wired headset connected to the phone. That way, the built-in microphone would be left unused, so it would be possible to determine whether the issue stems from the built-in microphone or from the routing of the audio signals. Maybe it's even up to the A/D conversion performed inside the A64 SoC?
I'll try to reproduce the issue, by placing my PinePhone in a metal enclosure, etc. By the way, back at the time when the modem calls initially started to work on the PinePhone, the dialer application didn't perform the audio routing. As a result, there was a loud noise during the call, resemblling some sort of weird, metallic, pulsating noise that made it impossible to hear the other end of the call, or the other end to hear me. After executing the audio setup utility, during the call, this noise disappeared and the audio quality was rather good afterwards. I wonder if this is somehow related?
(05-24-2021, 10:21 AM)vortex Wrote: The resulting spectrogram, which is where the bad news starts, is
Nice work on creating the analysis and plotting utility! The first thing that crossed my mind once I saw these spectrograms was "damn! the noise covers nearly the entire audible spectrum!" and it sadly turned out to be true after reading your explanation.
(05-24-2021, 10:21 AM)vortex Wrote: And then there is an important question. How widespread is this phenomena among PinePhones in low cellular signal conditions? For those that have it, is the frequency the same? This latter one is important for implementing any filter in a widespread fashion. If each phone with the problem has a different frequency, each phone will require tuning of the filter. If it is the same, then the parameters can be found very accurately using one or a handful of phones and used for all with the problem.
I'll try to reproduce the issue on my PinePhone, and hopefully more people would do the same. That's the only way to know how widespread the issue is, and whether it manifests in the same way on all affected phones.
Edit: I somehow managed to forget mentioning that the proprietary modem firmware can be updated, which you're probably already aware of, so you should check that as well. You can find the instructions, the latest firmware, and the release notes in this repository. Further information, including the source code of the update utility, can be found in this forum thread
Edit #2: Here's a very good insight from Biktorgj, who is the primary author of the open-source firmware for the PinePhone's Quectel modem. The quotation below comes from an IRC session on #pinedev, in which I asked Biktorgj to have a look at this forum thread.
Quote:Difficult to diagnose without hearing it and finding something to replicate.
I've always heard some noise from the modem during calls that seems to filter to the analog amp in the pinephone but it's never been a static whine, you can hear the "data" being moved between the bts and the modem like when you put a phone near an amplifier, but I'm always on 4G with VoLtE.
That said, the modem does have some gain compensation and white noise generation through the afe loop which can be making the problem worse. First I would try to adjust the output level to the modem, then I'd try without the AFE calibration and that stuff (my firmware doesn't have it).
The modem doesn't have any internal dac/adc for voice (it can be optionally attached to an external codec but the pinephone doesnt have one, so everything that the modem gets is digital).
The other thing that could be tried is setting audio to 16KHz if running stock firmware or to 48k if using the custom one, just in case the resampling is getting artifacts into the audio, but maybe that's useless.