FreeCalypso > hg > fc-tourmaline
view doc/Voice-pseudo-modem @ 220:0ed36de51973
ABB semaphore protection overhaul
The ABB semaphone protection logic that came with TCS211 from TI
was broken in several ways:
* Some semaphore-protected functions were called from Application_Initialize()
context. NU_Obtain_Semaphore() called with NU_SUSPEND fails with
NU_INVALID_SUSPEND in this context, but the return value wasn't checked,
and NU_Release_Semaphore() would be called unconditionally at the end.
The latter call would increment the semaphore count past 1, making the
semaphore no longer binary and thus no longer effective for resource
protection. The fix is to check the return value from NU_Obtain_Semaphore()
and skip the NU_Release_Semaphore() call if the semaphore wasn't properly
obtained.
* Some SPI hardware manipulation was being done before entering the semaphore-
protected critical section. The fix is to reorder the code: first obtain
the semaphore, then do everything else.
* In the corner case of L1/DSP recovery, l1_abb_power_on() would call some
non-semaphore-protected ABB & SPI init functions. The fix is to skip those
calls in the case of recovery.
* A few additional corner cases existed, all of which are fixed by making
ABB semaphore protection 100% consistent for all ABB functions and code paths.
There is still one remaining problem of priority inversion: suppose a low-
priority task calls an ABB function, and some medium-priority task just happens
to preempt right in the middle of that semaphore-protected ABB operation. Then
the high-priority SPI task is locked out for a non-deterministic time until
that medium-priority task finishes its work and goes back to sleep. This
priority inversion problem remains outstanding for now.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 26 Apr 2021 20:55:25 +0000 |
parents | a62e5bf88434 |
children |
line wrap: on
line source
Back when TI's TCS211 fw existed in the traditional world of phone handset and cellular modem manufacturers, there were only two principal classes of target devices for it: handsets and modems. The former have local UI hardware (LCDs and keypads) and run firmware that works with this UI hw, the latter have no such hw and run firmware that expects to be controlled by an external host via AT commands. But the peculiar circumstances under which our FreeCalypso family of projects operates give rise to a third possibility: what happens if one were to run non-UI-capable firmware that expects control via AT commands on a hardware target device that was originally designed to be an end user phone handset, in our case either Motorola C1xx or Pirelli DP-L10? The result is what I call a voice pseudo-modem (VPM): the phone's LCD stays dark, the buttons do nothing and the device expects to be controlled via AT commands as if it were a modem like the one in GTA01/02 smartphones, but there is no practically usable way to make use of any data services, only voice and SMS, hence my VPM term. It needs to be noted clearly that the VPM hack described in this article is NOT a substitute for proper modem hardware - if your area of interest is Standard Modem functionality (the full set of GSM and GPRS services accessed via AT commands), then you need a proper hardware platform for it, either FCDEV3B or Caramel2. However, support for VPM operation in FreeCalypso exists for the following purposes: * On some hw targets the VPM configuration can be an intermediate stepping stone toward potential future UI-enabled firmware - this situation holds on the C139. * Being able to run FreeCalypso fw in the VPM configuration on Mot C1xx hw that many people already have and that may still be readily and cheaply available makes our firmware accessible to those who are not able to buy new FreeCalypso hardware. * If you have a Pirelli DP-L10 phone (now very rare and hard to get, but were readily available in early 2013 when I started FreeCalypso): while there is unfortunately very little chance of being able to turn it into a practically usable Libre Dumbphone with FreeCalypso (the unwanted extra chips sans docs which we don't know how to power down are a killer), running FreeCalypso fw on the Pirelli in the VPM configuration is so easy and convenient that I do it all the time during development and testing. Playing with FreeCalypso VPM on C1xx phones =========================================== If a Mot C1xx phone is flashed with a FreeCalypso firmware image in the VPM configuration, it will behave as follows: * The LCD will remain dark and the buttons will do nothing no matter what. * If you plug in Motorola's charging adapter (it's a regulated 5 VDC power source, but with a non-USB connector) and you had properly installed the charging config file when creating the aftermarket FFS for FreeCalypso, the battery will charge. When you unplug the charging adapter, if there is no host computer running FC host program rvinterf connected to the phone serially, the phone will power off some 15 to 20 s after the charger unplug. * If you press the power button while the phone is off, even momentarily, the phone will power on and boot (with nothing on the LCD as usual), but if the headset jack serial port is not connected to a computer running rvinterf, the firmware will execute a power-off after at most 20 s. * In order to make the phone-turned-VPM do anything useful, you will need to connect the headset jack serial port to a host computer running FC host tools, run rvinterf to keep the phone alive (keep it from automatically powering off), and use FC host utility fc-shell to issue AT commands to it over the RVTMUX channel managed by rvinterf. * The phone will remain on (i.e., the fw won't execute an automatic power-off) for as long as there is either a charging power adapter plugged in or a connected host computer running rvinterf - if there is no charging power, the fw will send periodic keepalive queries to check for the presence of a connected rvinterf process. Playing with FreeCalypso VPM on a Pirelli DP-L10 ================================================ There are two ways in which one can play with FC VPM firmware on a Pirelli: * FC VPM fw can be flashed into the phone just like on Mot C1xx. To make this approach sensible, you will also need to craft and install a charging config file that will cause our FCHG driver to initiate the charging process automatically when the battery voltage falls below some sensible threshold, without requiring manual charging start via AT@CHG=1. In this case the reflashed phone will behave like C1xx in the previous section, except that the charging power source and the host computer connection are one and the same in the case of Pirelli's USB. * The other approach is to keep Pirelli's original fw in the flash, let the phone function normally when not in the middle of a FreeCalypso VPM session, and load our FC VPM fw into RAM via fc-xram, making use of this phone's huge RAM that can hold an entire functional fw image without flashing. This is the Mother's preferred method.