FreeCalypso > hg > fc-tourmaline
diff src/g23m-gprs/grlc/grlc_tpcg.c @ 1:fa8dc04885d8
src/g23m-*: import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:25:50 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/g23m-gprs/grlc/grlc_tpcg.c Fri Oct 16 06:25:50 2020 +0000 @@ -0,0 +1,250 @@ +/* ++----------------------------------------------------------------------------- +| Project : GPRS (8441) +| Modul : GRLC ++----------------------------------------------------------------------------- +| Copyright 2002 Texas Instruments Berlin, AG +| All rights reserved. +| +| This file is confidential and a trade secret of Texas +| Instruments Berlin, AG +| The receipt of or possession of this file does not convey +| any rights to reproduce or disclose its contents or to +| manufacture, use, or sell anything it may describe, in +| whole, or in part, without the specific written consent of +| Texas Instruments Berlin, AG. ++----------------------------------------------------------------------------- +| Purpose : This module implements local functions for service +| TPC of entity GRLC. ++----------------------------------------------------------------------------- +*/ + +/* + * !!!ATTENTION!!!ATTENTION!!!ATTENTION!!!ATTENTION!!!ATTENTION!!!ATTENTION!!! + * + * This file was previously named grlc_tpcf.c. + * + * A renaming was necessary due to an ClearCase evil twin problem across the + * TCS2/TCS3/TCS4 and the TCS5 programs. + * + * The same applied for the file grlc_tpcf.h. + * + * !!!ATTENTION!!!ATTENTION!!!ATTENTION!!!ATTENTION!!!ATTENTION!!!ATTENTION!!! + */ + +#ifndef GRLC_TPCG_C +#define GRLC_TPCG_C +#endif /* #ifndef GRLC_TPCG_C */ + +#define ENTITY_GRLC + +/*==== INCLUDES =============================================================*/ + +#include <string.h> +#include "typedefs.h" +#include "vsi.h" +#include "macdef.h" +#include "gprs.h" +#include "gsm.h" +#include "ccdapi.h" +#include "prim.h" +#include "message.h" +#include "grlc.h" + +/*==== CONST ================================================================*/ + +#define MIN_PCL_GSM900 31 /* minimum power control level GSM 900 */ +#define MAX_PCL_GSM900 0 /* maximum power control level GSM 900 */ +#define MIN_PCL_DCS1800 28 /* minimum power control level DCS 1800 */ +#define MAX_PCL_DCS1800 29 /* maximum power control level DCS 1800 */ +#define MIN_PCL_PCS1900 21 /* minimum power control level PCS 1900 */ +#define MAX_PCL_PCS1900 22 /* maximum power control level PCS 1900 */ + +#define GAMMA_0_GSM900 39 +#define GAMMA_0_DCS1800 36 +#define GAMMA_0_PCS1900 36 + +#define MAX_PCL 32 + +/*==== DIAGNOSTICS ==========================================================*/ + +/*==== LOCAL VARS ===========================================================*/ +/* + * The following tables converts the air-interface coding of + * the system information parameter MAX_TXPWR_CCCH to a value + * in dBm depending on the frequency standard (GSM, DCS or PCS). + */ +const UBYTE pcl_to_dbm_gsm [MAX_PCL] = +{ 39, /* 0 -> 39 dBm */ + 39, /* 1 -> 39 dBm */ + 39, /* 2 -> 39 dBm */ + 37, /* 3 -> 37 dBm */ + 35, /* 4 -> 35 dBm */ + 33, /* 5 -> 33 dBm */ + 31, /* 6 -> 31 dBm */ + 29, /* 7 -> 29 dBm */ + 27, /* 8 -> 27 dBm */ + 25, /* 9 -> 25 dBm */ + 23, /* 10 -> 23 dBm */ + 21, /* 11 -> 21 dBm */ + 19, /* 12 -> 19 dBm */ + 17, /* 13 -> 17 dBm */ + 15, /* 14 -> 15 dBm */ + 13, /* 15 -> 13 dBm */ + 11, /* 16 -> 11 dBm */ + 9, /* 17 -> 9 dBm */ + 7, /* 18 -> 7 dBm */ + 5, /* 19 -> 5 dBm */ + 5, /* 20 -> 5 dBm */ + 5, /* 21 -> 5 dBm */ + 5, /* 22 -> 5 dBm */ + 5, /* 23 -> 5 dBm */ + 5, /* 24 -> 5 dBm */ + 5, /* 25 -> 5 dBm */ + 5, /* 26 -> 5 dBm */ + 5, /* 27 -> 5 dBm */ + 5, /* 28 -> 5 dBm */ + 5, /* 29 -> 5 dBm */ + 5, /* 30 -> 5 dBm */ + 5 /* 31 -> 5 dBm */ +}; + +const UBYTE pcl_to_dbm_dcs [MAX_PCL] = +{ 30, /* 0 -> 30 dBm */ + 28, /* 1 -> 28 dBm */ + 26, /* 2 -> 26 dBm */ + 24, /* 3 -> 24 dBm */ + 22, /* 4 -> 22 dBm */ + 20, /* 5 -> 20 dBm */ + 18, /* 6 -> 18 dBm */ + 16, /* 7 -> 16 dBm */ + 14, /* 8 -> 14 dBm */ + 12, /* 9 -> 12 dBm */ + 10, /* 10 -> 10 dBm */ + 8, /* 11 -> 8 dBm */ + 6, /* 12 -> 6 dBm */ + 4, /* 13 -> 4 dBm */ + 2, /* 14 -> 2 dBm */ + 0, /* 15 -> 0 dBm */ + 0, /* 16 -> 0 dBm */ + 0, /* 17 -> 0 dBm */ + 0, /* 18 -> 0 dBm */ + 0, /* 19 -> 0 dBm */ + 0, /* 20 -> 0 dBm */ + 0, /* 21 -> 0 dBm */ + 0, /* 22 -> 0 dBm */ + 0, /* 23 -> 0 dBm */ + 0, /* 24 -> 0 dBm */ + 0, /* 25 -> 0 dBm */ + 0, /* 26 -> 0 dBm */ + 0, /* 27 -> 0 dBm */ + 0, /* 28 -> 0 dBm */ + 36, /* 29 -> 36 dBm */ + 34, /* 30 -> 34 dBm */ + 32 /* 31 -> 32 dBm */ +}; + +const UBYTE pcl_to_dbm_pcs [MAX_PCL] = +{ 30, /* 0 -> 30 dBm */ + 28, /* 1 -> 28 dBm */ + 26, /* 2 -> 26 dBm */ + 24, /* 3 -> 24 dBm */ + 22, /* 4 -> 22 dBm */ + 20, /* 5 -> 20 dBm */ + 18, /* 6 -> 18 dBm */ + 16, /* 7 -> 16 dBm */ + 14, /* 8 -> 14 dBm */ + 12, /* 9 -> 12 dBm */ + 10, /* 10 -> 10 dBm */ + 8, /* 11 -> 8 dBm */ + 6, /* 12 -> 6 dBm */ + 4, /* 13 -> 4 dBm */ + 2, /* 14 -> 2 dBm */ + 0, /* 15 -> 0 dBm */ + 0, /* 16 -> 0 dBm */ + 0, /* 17 -> 0 dBm */ + 0, /* 18 -> 0 dBm */ + 0, /* 19 -> 0 dBm */ + 0, /* 20 -> 0 dBm */ + 0, /* 21 -> 0 dBm */ + 33, /* 22 -> 33 dBm */ + 33, /* 23 -> 33 dBm */ + 33, /* 24 -> 33 dBm */ + 33, /* 25 -> 33 dBm */ + 33, /* 26 -> 33 dBm */ + 33, /* 27 -> 33 dBm */ + 33, /* 28 -> 33 dBm */ + 33, /* 29 -> 33 dBm */ + 33, /* 30 -> 33 dBm */ + 32 /* 31 -> 32 dBm */ +}; + +/*==== PRIVATE FUNCTIONS ====================================================*/ + +/*==== PUBLIC FUNCTIONS =====================================================*/ +/* ++------------------------------------------------------------------------------ +| Function : tpc_get_ms_pwr_cap ++------------------------------------------------------------------------------ +| Description : +| +| Parameters : +| ++------------------------------------------------------------------------------ +*/ +GLOBAL void tpc_get_ms_pwr_cap ( UBYTE band_indicator, + T_MS_PWR_CAP *ms_pwr_cap ) +{ + TRACE_FUNCTION( "tpc_get_ms_pwr_cap" ); + + switch( band_indicator ) + { + default: + case CGRLC_GSM_400: + case CGRLC_GSM_850: + case CGRLC_GSM_900: + ms_pwr_cap->p_control = pcl_to_dbm_gsm; + ms_pwr_cap->pwr_min = pcl_to_dbm_gsm[MIN_PCL_GSM900]; + ms_pwr_cap->gamma_0 = GAMMA_0_GSM900; + break; + + case CGRLC_DCS_1800: + ms_pwr_cap->p_control = pcl_to_dbm_dcs; + ms_pwr_cap->pwr_min = pcl_to_dbm_dcs[MIN_PCL_DCS1800]; + ms_pwr_cap->gamma_0 = GAMMA_0_DCS1800; + break; + + case CGRLC_PCS_1900: + ms_pwr_cap->p_control = pcl_to_dbm_pcs; + ms_pwr_cap->pwr_min = pcl_to_dbm_pcs[MIN_PCL_PCS1900]; + ms_pwr_cap->gamma_0 = GAMMA_0_PCS1900; + break; + } + +} /* tpc_get_ms_pwr_cap() */ + +/* ++------------------------------------------------------------------------------ +| Function : tpc_get_pcl ++------------------------------------------------------------------------------ +| Description : This function is used to convert the nominal output power to +| the power control level +| +| Parameters : p_ctrl - pointer to table of power control levels +| nop - nominal output power +| ++------------------------------------------------------------------------------ +*/ +GLOBAL UBYTE tpc_get_pcl ( UBYTE const *p_ctrl, SHORT nop ) +{ + UBYTE pcl = 0; /* power control level */ + + TRACE_FUNCTION( "tpc_get_pcl" ); + + /* get power control level */ + while( nop < (SHORT)p_ctrl[pcl] - 1 OR nop >= (SHORT)p_ctrl[pcl] + 1 ) pcl++; + + return( pcl ); + +} /* tpc_get_pcl() */ +