FreeCalypso > hg > fc-magnetite
view src/cs/drivers/drv_app/ffs/board/ffspcm.c @ 635:baa0a02bc676
niq32.c DTR handling restored for targets that have it
TI's original TCS211 fw treated GPIO 3 as the DTR input (wired so on C-Sample
and D-Sample boards, also compatible with Leonardo and FCDEV3B which have a
fixed pull-down resistor on this GPIO line), and the code in niq32.c called
UAF_DTRInterruptHandler() (implemented in uartfax.c) from the
IQ_KeypadGPIOHandler() function. But on Openmoko's GTA02 with their official
fw this GPIO is a floating input, all of the DTR handling code in uartfax.c
including the interrupt logic is still there, but the hobbled TCS211-20070608
semi-src delivery which OM got from TI contained a change in niq32.c (which
had been kept in FC until now) that removed the call to
UAF_DTRInterruptHandler() as part of those not-quite-understood "CC test"
hacks.
The present change fixes this bug at a long last: if we are building fw for a
target that has TI's "classic" DTR & DCD GPIO arrangement (dsample, fcmodem and
gtm900), we bring back all of TI's original code in both uartfax.c and niq32.c,
whereas if we are building fw for a target that does not use this classic GPIO
arrangement, the code in niq32.c goes back to what we got from OM and all
DTR & DCD code in uartfax.c is conditioned out. This change also removes the
very last remaining bit of "CC test" bogosity from our FreeCalypso code base.
| author | Mychaela Falconia <falcon@freecalypso.org> |
|---|---|
| date | Sun, 19 Jan 2020 01:41:35 +0000 |
| parents | 945cf7f506b2 |
| children |
line wrap: on
line source
/* * Flash File System (ffs) * * WCP PCM Compatibility Support */ #include <string.h> #include "main/sys_types.h" #include "memif/mem.h" #include "ffs/ffs.h" #include "ffs/board/ffspcm.h" #include "nucleus.h" #include "csmi/csmi.h" #include "csmi/csmi_gsmctrl.h" #include "ffs/pcm.h" // Factory FFS area description #pragma DATA_SECTION(FlashImage, ".ffs_img") const unsigned char FlashImage[0x4000]; /* * * ffs_InitRFCap * * Purpose : Set rfcap for tri-band config * * Arguments: In : none * * Out: none * * Returns : none * */ #define SIZE_EF_RFCAP 16 static const UBYTE rfcap_TriBand[SIZE_EF_RFCAP] = {0x00, 0x0F, 0x41, 0x10, 0x00, 0x00, 0x00, 0x00, \ 0x40, 0x00, 0x00, 0xA5, 0x05, 0x00, 0xC0, 0x00}; static const UBYTE rfcap_DualExt[SIZE_EF_RFCAP] = {0x00, 0x0B, 0x41, 0x00, 0x00, 0x00, 0x00, 0x00, \ 0x40, 0x00, 0x00, 0xA5, 0x05, 0x00, 0xC0, 0x00}; effs_t ffs_InitRFCap () { ffs_mkdir_nb("/gsm" ,0); ffs_mkdir_nb("/gsm/com" ,0); ffs_fwrite_nb("/gsm/com/rfcap", (void*)rfcap_TriBand, SIZE_EF_RFCAP, 0); } /* * * ffs_SetBand * * Purpose : Set std config according to the selected Band * * Arguments: In : Band number * * Out: none * * Returns : none * */ effs_t ffs_SetBand (unsigned char* band) { // Check validity of std band (1, 3 and 6 are supported) switch(*band) { case 1: case 3: case 6: // fall through break; default: return EFFS_BADNAME; } // Write STD file and set global variable ffs_fwrite_nb("/pcm/STD", band, 1, 0); } /* * * ffs_GetBand * * Purpose : Get STD config as recorded in FFS * * Arguments: In : none * * Out: none * * Returns : STD * */ unsigned char ffs_GetBand () { UBYTE ubStd = 0; effs_t result; // get FFS value result = ffs_fread("/pcm/STD", &ubStd, 1); // default if an error occured : 900-1800 if (result < EFFS_OK) { ubStd = 6; } return ubStd; } /* * ffs_restore * * Restores flash file system from MPU Persistent Storage * Restore Factory FFS in cae of file corruption * * Procedure described in PE023 document * */ void ffs_restore(void) { effs_t res; // FFS restore procedure started // send a message through CSMI if( GC_RestoreFFSReq(FFS_BASE_ADDRESS, IMAGE_SIZE) == CSMI_ERROR ) { // In case of MPU File corruption, // restore working FFS from factory FFS memcpy((char *) FFS_BASE_ADDRESS, FlashImage, IMAGE_SIZE); // backup FFS on MPU side // if we are running with the OS if(GC_RunningWithOs()) ffs_backup(); } } /* * ffs_backup * * Backup flash file system * * Procedure described in PE023 document * */ void ffs_backup(void) { // FFS backup procedure started // send a message through CSMI GC_BackupFFSReq(FFS_BASE_ADDRESS, IMAGE_SIZE); }
