view src/cs/layer1/tpu_drivers/source0/tpudrv10.h @ 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 4e78acac3d88
children
line wrap: on
line source

/****************** Revision Controle System Header ***********************
 *                      GSM Layer 1 software                                
 *              Copyright (c) Texas Instruments 1998                      
 *                                                                        
 *        Filename tpudrv10.h
 *  Copyright 2003 (C) Texas Instruments  
 *                                                                        
 ****************** Revision Controle System Header ***********************/

#define BIT_0       0x000001 
#define BIT_1       0x000002
#define BIT_2       0x000004
#define BIT_3       0x000008
#define BIT_4       0x000010
#define BIT_5       0x000020
#define BIT_6       0x000040
#define BIT_7       0x000080
#define BIT_8       0x000100
#define BIT_9       0x000200
#define BIT_10      0x000400
#define BIT_11      0x000800
#define BIT_12      0x001000
#define BIT_13      0x002000
#define BIT_14      0x004000
#define BIT_15      0x008000
#define BIT_16      0x010000
#define BIT_17      0x020000
#define BIT_18      0x040000
#define BIT_19      0x080000
#define BIT_20      0x100000
#define BIT_21      0x200000
#define BIT_22      0x400000
#define BIT_23      0x800000


//TRF6150 definitions
#define  MODE0           0x000000
#define  MODE1           0x000001
#define  MODE2           0x000002
#define  MODE3           0x000003
#define  MODE4           0x000004
#define  MODE5           0x000005
#define  MODE6           0x000006
#define  MODE7           0x000007

#define  REGUL_ON             BIT_3    //MODE0
#define  BG_SPEEDUP           BIT_4    //MODE0
#define  RX_ON_CLARA          BIT_5    //MODE0
#define  TX_ON_CLARA          BIT_6    //MODE0
#define  PA_CTRLR_ON          BIT_7    //MODE0
#define  AUX_SYNTH_ON         BIT_8    //MODE0
#define  MAIN_SYNTH_OFF       0x000000 //MODE0
#define  MAIN_SYNTH_ON_RX     BIT_9    //MODE0
#define  MAIN_SYNTH_ON_TX     BIT_10   //MODE0
#define  DCO_COMP_ON          BIT_11   //MODE0
#define  DCO_COMP_RUN         BIT_12   //MODE0
#define  BAND_SELECT_GSM      BIT_13   //MODE0
#define  BAND_SELECT_850      BIT_13   //MODE0
#define  BAND_SELECT_PCS      BIT_14   //MODE0
#define  BAND_SELECT_DCS     (BIT_14 | BIT_13)

#define  RX_RF_GAIN           BIT_15   //MODE0

// MODE1 is only for Receiver gain programming (AGC)

#define  AUX_SHDW_ADD(arfcn) ((arfcn >= 822) && (arfcn <= 885)) ? BIT_3 : 0 //MODE2
#define  AUX_SHDW_RCL         BIT_4    //MODE2
#define  MAIN_FCU_REG_100     BIT_7    //MODE2
#define  PA_CTRL_I_DIOD       BIT_23   //MODE2

//MODE3 
#define  TEST_MODE            BIT_3    //MODE3
#define  HB_OPLL_PRECHARGE    BIT_4    //MODE3

#define  HB_OPLL_CP_CUR_0_125MA   0x000000         //0.125 mA
#define  HB_OPLL_CP_CUR_0_25MA    BIT_5            //0.25 mA
#define  HB_OPLL_CP_CUR_0_5MA     BIT_6            //0.5 mA
#define  HB_OPLL_CP_CUR_1MA       (BIT_6 | BIT_5)  //1 mA
#define  HB_OPLL_CP_CUR_2MA       BIT_7            //2 mA  

#define  LB_OPLL_PRECHARGE    BIT_8    //MODE3

#define  LB_OPLL_CP_CUR_0_125MA   0x000000          //0.125 mA
#define  LB_OPLL_CP_CUR_0_25MA    BIT_9             //0.25 mA
#define  LB_OPLL_CP_CUR_0_5MA     BIT_10            //0.5 mA
#define  LB_OPLL_CP_CUR_1MA       (BIT_10 | BIT_9)  //1 mA
#define  LB_OPLL_CP_CUR_2MA       BIT_11            //2 mA 

#define  CLK_REF              BIT_17   //MODE3
#define  MAIN_VCO_EN          BIT_18   //MODE3
#define  AUX_VCO_EN           BIT_19   //MODE3
#define  EXT_VCO_CONTROL      BIT_20   //MODE3
#define  TEMP_SENSOR_EN       BIT_21   //MODE3

//MODE4
#define  MAIN_TIMER_RX_49_2US BIT_6     //MODE4
#define  MAIN_TIMER_RX_55_35US ( 8 << 3)  //added 30.01.02
#define  MAIN_TIMER_RX_61_5US (10 << 3)
#define  MAIN_TIMER_RX_78_9US (13 << 3)
#define  MAIN_TIMER_RX_91_9US (15 << 3)   
#define  MAIN_TIMER_RX_98_4US (16 << 3)   
#define  MAIN_TIMER_RX_159_9US (26 << 3)   //added 21.08 CR

 
#define  MAIN_TIMER_TX_49_2US BIT_11    //MODE4
#define  MAIN_TIMER_TX_61_5US (10 << 8)  //added 30.01.02
#define  MAIN_TIMER_TX_104US  (17 << 8)   //added for RS 
#define  MAIN_TIMER_TX_98_4US (16 << 8)
#define  MAIN_TIMER_TX_123US  (20 << 8)   //added 21.08 CR

#define  MAIN_CP_CUR_0        0x000000  //MODE4   400uA, 1.6mA
#define  MAIN_CP_CUR_1        BIT_21    //MODE4   400uA, 3.2mA
#define  MAIN_CP_CUR_2        BIT_22    //MODE4   800uA, 3.2mA
#define  MAIN_CP_CUR_3        (BIT_22 | BIT_21)//MODE4  same as 2

#define  FC_60                 (60 << 13)
#define  FC_63                 (63 << 13)
#define  FC_70                 (70 << 13)
#define  FC_100               (100 << 13)
#define  FC_109               (109 << 13)
#define  FC_110               (110 << 13)

//MODE5
#define  SHDW_LOAD            BIT_3     //MODE5 
#define  AUX_PRG_MOD          BIT_4     //MODE5
#define  AUX_PFD              BIT_14    //MODE5

//MODE6
#define  FREQ_CAL_ON          BIT_4     //MODE6
#define  FREQ_CAL_MODE        BIT_5     //MODE6

//MODE7
#define FREQ_CAL_DATA         (0xd << 19)     // 6.15  (00000)-8.88 (01101)-12.66 pF (11111)- modified CR 11.09.01, was   (0xb << 19) 


// RF signals connected to TSPACT  [0..7]
//#define RESET_RF      BIT_0  // act0
#define CLA_SER_ON    BIT_0  // act0 
#define CLA_SER_OFF   0      
#define TXVCO_ON      0      // act3 inverted
#define TXVCO_OFF     BIT_3
#define TX_ON         BIT_5  // act5
#define TX_OFF        0    

// RF signals connected to TSPACT for Titanium v2.2
#if 0
//B-Sample
#define PA900_ON      BIT_2  // signals are inverted therefore PA900_ON act1
#define PA1800_ON     BIT_1  // and PA1800_ON act2
#define PA900_OFF     BIT_1  // 
#define PA1800_OFF    BIT_2  // 
#endif

#if 0
//C-Sample
#define PA900_ON      BIT_1  // signals are inverted therefore PA900_ON act1
#define PA1800_ON     BIT_2  // and PA1800_ON act2
#define PA900_OFF     BIT_2  // 
#define PA1800_OFF    BIT_1  // 
#endif

#if 1
//D-Sample
#define  PA900_ON     BIT_1  // signals are inverted therefore PA900_ON act1
#define PA1800_ON     BIT_2  // and PA1800_ON act2
#define RX1900_ON     0  
#define  PA900_OFF    BIT_2  // 
#define PA1800_OFF    BIT_1  // 
#define RX1900_OFF    BIT_4

//RX_UP/DOWN and TX_UP/DOWN 
#define RU_900     (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define RD_900     (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_900     (PA900_ON  | PA1800_OFF | RX1900_OFF)
#define TD_900     (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_REV_900  (PA900_OFF | PA1800_ON  | RX1900_OFF)

#define RU_850     (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define RD_850     (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_850     (PA900_ON  | PA1800_OFF | RX1900_OFF)
#define TD_850     (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_REV_850  (PA900_OFF | PA1800_ON  | RX1900_OFF)

#define RU_1800    (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define RD_1800    (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_1800    (PA900_OFF | PA1800_ON  | RX1900_OFF)
#define TD_1800    (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_REV_1800 (PA900_ON  | PA1800_OFF | RX1900_OFF)

#define RU_1900    (PA900_OFF | PA1800_OFF | RX1900_ON)
#define RD_1900    (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_1900    (PA900_OFF | PA1800_ON  | RX1900_OFF)
#define TD_1900    (PA900_OFF | PA1800_OFF | RX1900_OFF)
#define TU_REV_1900 (PA900_ON  | PA1800_OFF | RX1900_OFF)


#endif

#define TC1_DEVICE_ABB     TC1_DEVICE0
#define TC1_DEVICE_RF      TC1_DEVICE2 


  #define SL_SU_DELAY1 4  // No. bits to send + load data to shift + send write cmd + 1
  #define SL_SU_DELAY2 3  // load data to shift + send write cmd + 1
  #define SL_SU_DELAY3 5  // SL_SU_DELAY1 + serialization

#define DLT  20  // (TRF6150) DownLoadTime

#define DLT_1     1   // 1 tpu instruction = 1 qbit
#define DLT_2     2 
#define DLT_3     3 
 
#define DLT_1B    4   // 3*move + 1*byte (download)
#define DLT_2B    6   // 4*move + 2*byte
#define DLT_3B    8   // 5*move + 3*byte

//#define crch_timing 420//250//420//0 // CR d.07.08.01 - Temperary movement of Rx and Tx timing for Titanium. Will be set to 0 when new LF is ready.
#define rdt       0//359  // rx delta timing
#define tdt       0//293  // tx delta timing

/*------------------------------------------*/
/*        Download delay values             */
/*------------------------------------------*/
// 0.9230769 usec ~ 1 qbit i.e. 200 usec is ~ 217 qbit
 
#define T TPU_CLOCK_RANGE  
 
#define TRF_I7   334  //qbit 
#define TRF_I8   378  //qbit

// time below are offset to when BDLENA goes low 
#define TRF_R15  (   0 - DLT_1B)   // 0, BDLENA low, needs DLT_1B to execute
#define TRF_R13  ( - 32 - DLT_1B)   // 8 right after, power off transceiver

//burst data comes here
// time below are offset to when BDLENA goes high
#define TRF_R12  (PROVISION_TIME -   0 - DLT_1B)        // BDLENA i/q comes 32qbit later
#define TRF_R10  (PROVISION_TIME -   8 - DLT_1B)        // Set RX/TX switch (not really necessary as the default setting is RX mode)
#define TRF_R9   (PROVISION_TIME -  16 - DLT_2B)  // RX_ON_CLARA
#define TRF_R7   (PROVISION_TIME -  66 - DLT_1B)        // 67qbit duration BDLON + BDLCAL
#define TRF_R6   (PROVISION_TIME -  83 - DLT_1B)        // BDLON, RX_ON_CLARA
#define TRF_R5   (PROVISION_TIME - 172 - DLT_2B - rdt)  // DC offset comp. start LNA ON
//#define TRF_R4   (PROVISION_TIME - 172 - DLT_2B - rdt)  // DC offset comp. LNA
#define TRF_R3   (PROVISION_TIME - 177 - DLT_2B - rdt)  // DC offset comp. GAIN
//l1dmacro_adc_read_rx() called here requires ~ 16 tpuinst
//#define TRF_R2_1 (PROVISION_TIME - 199 - DLT_2B - rdt)  // fc
//#define TRF_R2   (PROVISION_TIME - 199 - DLT_2B - rdt)  // select band
#define TRF_R1   (PROVISION_TIME - 209 - DLT_3B - rdt)  // Main PLL + set of Main PLL FC & CP current


// time below are offset to when BULENA goes low 
#define TRF_T17   (   32 - SL_SU_DELAY2)    // right after, BULON low
//#define TRF_T17   (   32 )    // right after, BULON low
#define TRF_T16   (   26 - DLT_1B)    // Power down Clara
#define TRF_T15   (   14 - DLT_1)     // disable TX_ON
#define TRF_T14   (    0 - DLT_1B)    // BULENA off
#define TRF_T13_3 (-  40 - DLT_1B)    // ADC read
//burst data comes here
// time below are offset to when BULENA goes high
#define TRF_T13_2 (   25 - DLT_1)     //  TX_ON
#define TRF_T13_1 (   17 - DLT_1)     //  set rf switch 
#define TRF_T12   (-   0 - DLT_1B)    //  BULENA Start of TX burst
#define TRF_T10   (-  70 - DLT_3B - tdt)    //  normal speed
#define TRF_T9    (- 121 - DLT_2B - tdt)    //  Power up TXVCO
#define TRF_T8    (- 127 - DLT_1B - tdt)    //  BULON, disable BULCAL
#define TRF_T7    (- 127 - DLT_1B - tdt)    //  131 BULON, disable BULCAL
#define TRF_T6    (- 137 - DLT_3B - tdt)    //  Speed up
#define TRF_T4    (- 249 - DLT_1B - tdt)    //  prog AUX PLL & detector polarity
#define TRF_T3_1  (- 258 - DLT_2B - tdt)    //  fc
#define TRF_T3    (- 258 - DLT_2B - tdt)    //  20 BULON + BULCAL + select band				
#define TRF_T2    (- 267 - DLT_3B - tdt)    //  set of Main PLL FC & CP current		 
#define TRF_T1    (- 277 - DLT_3B - tdt)    //  BULON + Main PLL


/*------------------------------------------*/
/*   Is arfcn in the DCS band (512-885) ?   */
/*------------------------------------------*/
// is working only for GSM and DCS (not PCN)
#define IS_DCS_HIGH(arfcn) (((arfcn >= 576) && (arfcn <= 885))? 1 : 0)    //Changed by CR 30.08.01, was (((arfcn >= 822) && (arfcn <= 885))? 1 : 0)

#ifdef TPUDRV10_C

#endif