FreeCalypso > hg > fc-tourmaline
diff src/cs/layer1/tpu_drivers/source/tpudrv.c @ 0:4e78acac3d88
src/{condat,cs,gpf,nucleus}: import from Selenite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:23:26 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/cs/layer1/tpu_drivers/source/tpudrv.c Fri Oct 16 06:23:26 2020 +0000 @@ -0,0 +1,571 @@ +/************* Revision Controle System Header ************* + * GSM Layer 1 software + * + * Filename tpudrv.c + * Copyright 2003 (C) Texas Instruments + * + ************* Revision Controle System Header *************/ +/* + * TPUDRV.C + * + * TPU driver for Pole Star + * + * + * Copyright (c) Texas Instruments 1996 + * + */ + +#include "l1_macro.h" +#include "iq.h" +#include "l1_confg.h" +#include "l1_const.h" +#include "l1_types.h" + +#if (AUDIO_TASK == 1) + #include "l1audio_const.h" + #include "l1audio_cust.h" + #include "l1audio_defty.h" +#endif + +#if (L1_GTT == 1) + #include "l1gtt_const.h" + #include "l1gtt_defty.h" +#endif + +#if (L1_MIDI == 1) + #include "l1midi_defty.h" +#endif + +#include "sys_types.h" + +#if TESTMODE + #include "l1tm_defty.h" +#endif + +#if (L1_MP3 == 1) + #include "l1mp3_defty.h" +#endif + +#if (L1_MIDI == 1) + #include "l1midi_defty.h" +#endif + +#if (L1_AAC == 1) + #include "l1aac_defty.h" +#endif +#include "l1_defty.h" +#include "tpudrv.h" +#include "sys_types.h" +#include "clkm.h" +#include "l1_time.h" +#include "l1_varex.h" +#include "l1_trace.h" + +#if (L1_MADC_ON == 1) +#if (RF_FAM == 61) +#include "drp_api.h" +#include "l1_rf61.h" +#include "drp_drive.h" +#include "tpudrv61.h" +extern T_DRP_REGS_STR *drp_regs; +#endif +#endif //L1_MADC_ON + +/* RFTime environment */ +#if defined (HOST_TEST) + #include "hostmacros.h" +#endif + + +/* + * VEGA and OMEGA receive windows - Defined in Customer-specific file + */ + +extern UWORD32 debug_tpu; + +#if ( OP_WCP == 1 ) && ( OP_L1_STANDALONE != 1 ) + // WCS Patch : ADC during RX or TX + extern inline void GC_SetAdcInfo(unsigned char bTxBasedAdc); +#endif + +/* + * Global Variables + */ +// GSM1.5 : TPU MEMORY is 16-bit instead of 32 in Gemini/Polxx +//------------------------------------------------------------ +SYS_UWORD16 *TP_Ptr = (SYS_UWORD16 *) TPU_RAM; + + +/*--------------------------------------------------------------*/ +/* TPU_Reset : Reset the TPU */ +/*--------------------------------------------------------------*/ +/* Parameters : on/off(1/0) */ +/* Return : none */ +/* Functionality : ) Reset the TPU */ +/*--------------------------------------------------------------*/ +void TPU_Reset(SYS_UWORD16 on) +{ + if (on) + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) |= TPU_CTRL_RESET; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (!((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_RESET)); + } + else + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) &= ~TPU_CTRL_RESET; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_RESET)); + } +} + +/*--------------------------------------------------------------*/ +/* TSP_Reset : Reset the TSP */ +/*--------------------------------------------------------------*/ +/* Parameters : on/off(1/0) */ +/* Return : none */ +/* Functionality : ) Reset the TSP */ +/*--------------------------------------------------------------*/ +void TSP_Reset(SYS_UWORD16 on) +{ + if (on) + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) |= TSP_CTRL_RESET; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (!((*(volatile SYS_UWORD16 *) TPU_CTRL) & TSP_CTRL_RESET)); + } + else + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) &= ~TSP_CTRL_RESET; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (((*(volatile SYS_UWORD16 *) TPU_CTRL) & TSP_CTRL_RESET)); + } +} + +/*--------------------------------------------------------------*/ +/* TPU_SPIReset : Reset the SPI of the TPU */ +/*--------------------------------------------------------------*/ +/* Parameters : on/off(1/0) */ +/* Return : none */ +/* Functionality : ) the SPI of the TPU */ +/*--------------------------------------------------------------*/ + +void TPU_SPIReset(SYS_UWORD16 on) +{ + if (on) + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) |= TPU_CTRL_SPI_RST; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (!((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_SPI_RST)); + } + else + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) &= ~TPU_CTRL_SPI_RST; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_SPI_RST)); + } +} + +/*--------------------------------------------------------------*/ +/* TPU_ClkEnable : */ +/*--------------------------------------------------------------*/ +/* Parameters : on/off(1/0) */ +/* Return : none */ +/* Functionality : Enable the TPU clock */ +/*--------------------------------------------------------------*/ + +void TPU_ClkEnable(SYS_UWORD16 on) +{ + if (on) + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) |= TPU_CTRL_CLK_EN; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (!((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_CLK_EN)); + } + else + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) &= ~TPU_CTRL_CLK_EN; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_CLK_EN)); + } +} + +/*--------------------------------------------------------------*/ +/* TPU_Frame_ItOn : */ +/*--------------------------------------------------------------*/ +/* Parameters : bit of it to enable */ +/* Return : none */ +/* Functionality : Enable frame it */ +/*--------------------------------------------------------------*/ + +/*-----------------------------------------------------------*/ +/* Warning read modify write access to TPU_INT_CTRL register */ +/* may generate problems using Hyperion. */ +/*-----------------------------------------------------------*/ + +void TPU_FrameItOn(SYS_UWORD16 it) +{ + * ((volatile SYS_UWORD16 *) TPU_INT_CTRL) &= ~it; +} + +void TPU_FrameItEnable(void) +{ + #if W_A_ITFORCE + (*(volatile SYS_UWORD16 *)TPU_INT_CTRL) |= TPU_INT_ITD_F; + #else + // enable IT_DSP generation on next frame + // reset by DSP when IT occurs + (*(volatile SYS_UWORD16 *) TPU_CTRL) |= TPU_CTRL_D_ENBL; + // WA for read/modify/write access problem with REG_TPU_CTRL present on Ulysse/Samson/Calypso + while (!((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_D_ENBL)); + #endif +} + +/*--------------------------------------------------------------*/ +/* TPU_check_IT_DSP : */ +/*--------------------------------------------------------------*/ +/* Parameters : none */ +/* Return : none */ +/* Functionality : check if an IT DSP still pending */ +/*--------------------------------------------------------------*/ +BOOL TPU_check_IT_DSP(void) +{ // return TRUE if an IT DSP still pending. + return( (((*(volatile SYS_UWORD16 *) TPU_CTRL) & TPU_CTRL_D_ENBL) == TPU_CTRL_D_ENBL)); +} + +/*--------------------------------------------------------------*/ +/* TPU_DisableAllIt : */ +/*--------------------------------------------------------------*/ +/* Parameters : none */ +/* Return : none */ +/* Functionality : Disabl all it */ +/*--------------------------------------------------------------*/ +void TPU_DisableAllIt() +{ + * ((volatile SYS_UWORD16 *) TPU_INT_CTRL) |= TPU_INT_ITF_M | TPU_INT_ITP_M | TPU_INT_ITD_M; + +} + + +/* + * TP_Program + * + * Write a null-terminated scenario into TPU memory at a given start address + * (Do not write terminating 0) + * + */ +void TP_Program(const SYS_UWORD16 *src) +{ + /* Write TPU instructions until SLEEP */ + while (*src) + { + *TP_Ptr++ = *src++; + } +} + + +void TP_Reset(SYS_UWORD16 on) +{ + if (on) { + * ((volatile SYS_UWORD16 *) TPU_CTRL) |= (TPU_CTRL_RESET | TSP_CTRL_RESET); + while (!((*(volatile SYS_UWORD16 *) TPU_CTRL) & (TPU_CTRL_RESET | TSP_CTRL_RESET))); + } + else { + * ((volatile SYS_UWORD16 *) TPU_CTRL) &= ~(TPU_CTRL_RESET | TSP_CTRL_RESET); + while (((*(volatile SYS_UWORD16 *) TPU_CTRL) & (TPU_CTRL_RESET | TSP_CTRL_RESET))); + } +} + +void TP_Enable(SYS_UWORD16 on) +{ + if(on) + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) |= TPU_CTRL_T_ENBL; + + // Some time shall be wait before leaving the function to ensure that bit has been taken + // in account by the TPU. A while loop such as in function TP_reset can't be used as the + // ARM can be interrupted within this loop and in that case the pulse will be missed (CQ20781). + // The bit is updated in the worst case 24 cycles of 13MHz later it as been written by the MCU. + // 24 ticks of 13MHz = 1.84us. Lets take 3us to keep some margin. + wait_ARM_cycles(convert_nanosec_to_cycles(3000)); // wait 3us + } + else + { + * ((volatile SYS_UWORD16 *) TPU_CTRL) &= ~TPU_CTRL_T_ENBL; + // Some time shall be wait before leaving the function to ensure that bit has been taken + // in account by the TPU. A while loop such as in function TP_reset can't be used as the + // ARM can be interrupted within this loop and in that case the pulse will be missed (CQ20781). + // The bit is updated in the worst case 24 cycles of 13MHz later it as been written by the MCU. + // 24 ticks of 13MHz = 1.84us. Lets take 3us to keep some margin. + wait_ARM_cycles(convert_nanosec_to_cycles(3000)); // wait 3us + } +} + + +#if 0 /* FreeCalypso: function not present in TCS211 */ +/*-----------------------------------------------------------------------*/ +/* Function name: TPU_wait_idle */ +/*-----------------------------------------------------------------------*/ +/* */ +/* Parameters: None */ +/* */ +/* Return: None */ +/* */ +/*-----------------------------------------------------------------------*/ +/* Description: Wait until TPU scenario execution is complete */ +/* */ +/*-----------------------------------------------------------------------*/ +void TPU_wait_idle(void) +{ + while( ((*(volatile SYS_UWORD16 *) (TPU_CTRL)) & TPU_CTRL_TPU_IDLE) == TPU_CTRL_TPU_IDLE) + { + wait_ARM_cycles(convert_nanosec_to_cycles(3000)); + } +} +#endif + + +/* + * l1dmacro_idle + * + * Write SLEEP instruction, start TPU and reset pointer + */ +void l1dmacro_idle (void) +{ + *TP_Ptr++ = TPU_SLEEP; + + /* start TPU */ + TP_Ptr = (SYS_UWORD16 *) TPU_RAM; + TP_Enable(1); +} + +/* + * l1dmacro_offset + * + * Set OFFSET register + * + */ +void l1dmacro_offset (UWORD32 offset_value, WORD32 relative_time) +{ + // WARNING: 'relative time' and 'offset_value' must always be comprised + // between 0 and TPU_CLOCK_RANGE !!! + + if (relative_time != IMM) // IMM indicates to set directly without AT + { + *TP_Ptr++ = TPU_FAT(relative_time); + } + *TP_Ptr++ = TPU_OFFSET(offset_value); +} + +/* + * l1dmacro_synchro + * + * Set synchro register + */ +void l1dmacro_synchro (UWORD32 when, UWORD32 value) +{ + // WARNING: 'when' must always be comprised between 0 and TPU_CLOCK_RANGE !!! + #if (TRACE_TYPE!=0) && (TRACE_TYPE!=5) + trace_fct(CST_L1DMACRO_SYNCHRO, -1); + #endif + + if (value != IMM) // IMM indicates to set directly without AT + { + *TP_Ptr++ = TPU_FAT(when); + } + + *TP_Ptr++ = TPU_SYNC(value); + l1s.tpu_offset_hw = value; // memorize the offset set into the TPU. +} + + +/* + * l1dmacro_adc_read + * + */ +void l1dmacro_adc_read_rx(void) +{ + + #if ((ANLG_FAM == 1) || (ANLG_FAM == 2) || (ANLG_FAM == 3)) + // TSP needs to be configured in order to send serially to Omega + +// *TP_Ptr++ = TPU_MOVE (TSP_SPI_SET1, TSP_CLK_RISE); // Clock configuration + *TP_Ptr++ = TPU_WAIT (5); + *TP_Ptr++ = TPU_MOVE (TSP_CTRL1,6); // Device and Nb of bits configuration + *TP_Ptr++ = TPU_MOVE (TSP_TX_REG_1,STARTADC); // Load data to send + *TP_Ptr++ = TPU_MOVE (TSP_CTRL2, TC2_WR); // Start serialization command and adc conversion + *TP_Ptr++ = TPU_WAIT (5); + *TP_Ptr++ = TPU_MOVE (TSP_TX_REG_1,0x00); + *TP_Ptr++ = TPU_MOVE (TSP_CTRL2, TC2_WR); // Reset startadc pulse + + #if (TRACE_TYPE==1)||(TRACE_TYPE ==4) + #if (GSM_IDLE_RAM == 0) + l1_trace_ADC(0); + #else + l1_trace_ADC_intram(0); + #endif + #endif + #endif + +#if (L1_MADC_ON == 1) + #if (ANLG_FAM == 11) + + #if (TRACE_TYPE==1)||(TRACE_TYPE ==4) + #if (GSM_IDLE_RAM == 0) + l1_trace_ADC(0); + #else + l1_trace_ADC_intram(0); + #endif + #endif + #endif + + #if (OP_WCP == 1) && (OP_L1_STANDALONE != 1) + // WCS patch: ADC during RX + GC_SetAdcInfo(0); + #endif +#endif +} + + +#if (CODE_VERSION != SIMULATION) +#if (L1_MADC_ON ==1) +/* + * l1dmacro_adc_read_rx_cs_mode0 + * + * Purpose: + * ====== + * MADC is not enabled during CS_MODE0 periodically. MADC is enabled in CS_MODE0 + * when Layer 1 receives MPHC_RXLEV_REQ from L23. However in CS_MODE0, MPHC_RXLEV_REQ + * is not received periodically. In case network is not found, the period between 2 MPHC_RXLEV_REQ + * increases and can be as high as 360 seconds (Maximum Value) + * This can result in battery related issues like phone powering off without MMI indication. + */ + + +void l1dmacro_adc_read_rx_cs_mode0(void) +{ + *TP_Ptr++ = TPU_MOVE(REG_SPI_ACT_U,START_ADC); + *TP_Ptr++ = TPU_WAIT (2); + *TP_Ptr++ = TPU_MOVE(REG_SPI_ACT_U,0); + +#if (L1_MADC_ON == 1) + #if (ANLG_FAM == 11) + + #if (TRACE_TYPE==1)||(TRACE_TYPE ==4) + #if (GSM_IDLE_RAM == 0) + l1_trace_ADC(0); + #else + l1_trace_ADC_intram(0); + #endif + #endif + #endif + + #if (OP_WCP == 1) && (OP_L1_STANDALONE != 1) + // WCS patch: ADC during RX + GC_SetAdcInfo(0); + #endif +#endif +} + + +#endif //If MADC is enabled +#endif //If Not Simulation + +/* + * l1dmacro_adc_read_tx + * + */ + + +#if (ANLG_FAM != 11) +void l1dmacro_adc_read_tx(UWORD32 when) +#else +void l1dmacro_adc_read_tx(UWORD32 when, UWORD8 tx_up_state) +#endif +{ + + #if ((ANLG_FAM == 1) || (ANLG_FAM == 2) || (ANLG_FAM == 3)) + + *TP_Ptr++ = TPU_FAT (when); + *TP_Ptr++ = TPU_MOVE (TSP_CTRL1,6); // Device and Nb of bits configuration + *TP_Ptr++ = TPU_MOVE (TSP_TX_REG_1, STARTADC|BULON|BULENA); // Load data to send + *TP_Ptr++ = TPU_MOVE (TSP_CTRL2, TC2_WR); // Start serialization command and adc conversion + *TP_Ptr++ = TPU_WAIT (5); + *TP_Ptr++ = TPU_MOVE (TSP_TX_REG_1, BULON|BULENA); + *TP_Ptr++ = TPU_MOVE (TSP_CTRL2, TC2_WR); // Reset startadc pulse + + #if (TRACE_TYPE==1)||(TRACE_TYPE ==4) + l1_trace_ADC(1); + #endif + #endif + +#if (L1_MADC_ON == 1) + #if (ANLG_FAM == 11) + *TP_Ptr++ = TPU_FAT (when); + *TP_Ptr++ = TPU_MOVE(REG_SPI_ACT_U,tx_up_state | START_ADC); + *TP_Ptr++ = TPU_WAIT (2); + *TP_Ptr++ = TPU_MOVE(REG_SPI_ACT_U,tx_up_state); + +#if 1 // TEMP MEASUREMENT - uncomment and test after MADC +#if (RF_FAM == 61) + *TP_Ptr++ = TPU_MOVE(OCP_DATA_MSB, ((START_SCRIPT(DRP_TEMP_CONV))>>8) & 0xFF); \ + *TP_Ptr++ = TPU_MOVE(OCP_DATA_LSB, (START_SCRIPT(DRP_TEMP_CONV)) & 0xFF); \ + *TP_Ptr++ = TPU_MOVE(OCP_ADDRESS_MSB, (((UWORD16)( ((UWORD32)(&drp_regs->SCRIPT_STARTL))&0xFFFF)>>8) & 0xFF)); \ + *TP_Ptr++ = TPU_MOVE(OCP_ADDRESS_LSB, ((UWORD16)( ((UWORD32)(&drp_regs->SCRIPT_STARTL))&0xFFFF)) & 0xFF); \ + *TP_Ptr++ = TPU_MOVE(OCP_ADDRESS_START, 0x01); \ + //TEMP_MEAS: Call TEMP Conv Script in DRP + //MOVE_REG_TSP_TO_RF(START_SCRIPT(DRP_TEMP_CONV),(UWORD16)(&drp_regs->SCRIPT_STARTL)); +#endif + +#endif + + #if (TRACE_TYPE==1)||(TRACE_TYPE ==4) + l1_trace_ADC(1); + #endif + + #endif +#endif //L1_MADC_ON + + #if (OP_WCP == 1) && (OP_L1_STANDALONE != 1) + // WCS patch: ADC during TX + GC_SetAdcInfo(1); + #endif + + +} + + +/* +#if (RF_FAM == 61) + +void l1dmacro_adc_read_tx(UWORD32 when, UWORD8 tx_up_state) +{ + int i; + + *TP_Ptr++ = TPU_FAT (when); + *TP_Ptr++ = TPU_MOVE(REG_SPI_ACT_U,tx_up_state | START_ADC); + *TP_Ptr++ = TPU_WAIT (2); + *TP_Ptr++ = TPU_MOVE(REG_SPI_ACT_U,tx_up_state); + + #if (TRACE_TYPE==1)||(TRACE_TYPE ==4) + l1_trace_ADC(1); + #endif + + + #if (OP_WCP == 1) && (OP_L1_STANDALONE != 1) + // WCS patch: ADC during TX + GC_SetAdcInfo(1); + #endif +} + +#endif +*/ + +/* + * l1dmacro_set_frame_it + * + */ +void l1dmacro_set_frame_it(void) +{ + TPU_FrameItEnable(); +}