view doc/Blob-status @ 244:96784b8974eb

Switch_ON(): detect charging mode by CHGPRES bit Consider the following scenario: the phone is on, the user plugs in the charger, and then executes the power-off operation. In the Iota VRPC this sequence translates to a switch-off immediately followed by another switch-on - but the CHGSTS bit doesn't get set on the second switch-on cycle! Disassembly of Pirelli's fw shows that they check the CHGPRES bit, and furthermore, if both CHGPRES and ONBSTS are set, the code they pass to their modified Power_ON_Button() function is the one for charging - so let's adopt the same CHGPRES check and the same priority order for switch-on causes.
author Mychaela Falconia <falcon@freecalypso.org>
date Mon, 03 May 2021 06:51:29 +0000
parents a62e5bf88434
children
line wrap: on
line source

State of blobs in FreeCalypso firmware
======================================

FC Tourmaline is almost completely deblobbed.  Only the following very small
components exist in the form of blobs (prebuilt binary objects for which we
have no exact corresponding source) in the standard Tourmaline build:

* OSL and OSX glue components of GPF: 14992 bytes of code
* TMS470 compiler's RTS library (libc/libgcc equivalent): 13152 bytes of code

For OSL and OSX we do have reconstructed C code written based on disassembly of
the blobs, but I (Mother Mychaela) do not consider the current state of this C
reconstruction to be fit for production use - hence standard Tourmaline fw
builds use blob versions of these components.  However, our configuration and
build system gives you the freedom to select which version of each component
you would rather use; the selection is made with Bourne shell config variables
on the configure.sh invokation line:

OSL=0	use the blob version of OSL
OSL=1	use the reconstructed C version of OSL
OSX=0	use the blob version of OSX
OSX=1	use the reconstructed C version of OSX

The current default is OSL=0 and OSX=0.

RTS library
===========

We do have source code for some versions of the TMS470 compiler's RTS library,
but they may not be exactly corresponding to the blob version from TCS211 which
we are using.  This area is deemed to be such a low priority that no real
investigation has been done yet.