FreeCalypso > hg > fc-selenite
comparison src/g23m-gprs/grlc/grlc_measf.c @ 1:d393cd9bb723
src/g23m-*: initial import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 15 Jul 2018 04:40:46 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
0:b6a5e36de839 | 1:d393cd9bb723 |
---|---|
1 /* | |
2 +----------------------------------------------------------------------------- | |
3 | Project : GPRS (8441) | |
4 | Modul : GRLC | |
5 +----------------------------------------------------------------------------- | |
6 | Copyright 2002 Texas Instruments Berlin, AG | |
7 | All rights reserved. | |
8 | | |
9 | This file is confidential and a trade secret of Texas | |
10 | Instruments Berlin, AG | |
11 | The receipt of or possession of this file does not convey | |
12 | any rights to reproduce or disclose its contents or to | |
13 | manufacture, use, or sell anything it may describe, in | |
14 | whole, or in part, without the specific written consent of | |
15 | Texas Instruments Berlin, AG. | |
16 +----------------------------------------------------------------------------- | |
17 | Purpose : This module implements local functions for service | |
18 | MEAS of entity GRLC. | |
19 +----------------------------------------------------------------------------- | |
20 */ | |
21 | |
22 #ifndef GRLC_MEASF_C | |
23 #define GRLC_MEASF_C | |
24 #endif /* #ifndef GRLC_MEASF_C */ | |
25 | |
26 #define ENTITY_GRLC | |
27 | |
28 /*==== INCLUDES =============================================================*/ | |
29 | |
30 #include "typedefs.h" | |
31 #include "vsi.h" | |
32 #include "macdef.h" | |
33 #include "gprs.h" | |
34 #include "gsm.h" | |
35 #include "ccdapi.h" | |
36 #include "prim.h" | |
37 #include "message.h" | |
38 #include "grlc.h" | |
39 #include "grlc_measf.h" | |
40 | |
41 /*==== CONST ================================================================*/ | |
42 | |
43 #define I_LEVEL_MIN I_LEVEL_0 | |
44 #define I_LEVEL_0 0 /* i.lev. is greater than C */ | |
45 #define I_LEVEL_15 15 /* i.lev. is less than or equal to C - 28 dB */ | |
46 #define I_LEVEL_MAX I_LEVEL_15 | |
47 #define I_LEVEL_GAMMA_0_SKIPPED 0xF0 /* used for tracing */ | |
48 #define I_LEVEL_GAMMA_1_SKIPPED 0xF1 /* used for tracing */ | |
49 #define I_LEVEL_GAMMA_2_SKIPPED 0xF2 /* used for tracing */ | |
50 #define I_LEVEL_GAMMA_3_SKIPPED 0xF3 /* used for tracing */ | |
51 #define I_LEVEL_STATE_MISMATCH 0xFD /* used for tracing */ | |
52 #define I_LEVEL_IDX_TO_SMALL 0xFE /* used for tracing */ | |
53 #define I_LEVEL_NOT_AVAIL 0xFF /* used for tracing */ | |
54 | |
55 /*==== LOCAL VARS ===========================================================*/ | |
56 | |
57 /*==== LOCAL TYPES===========================================================*/ | |
58 | |
59 /*==== PUBLIC FUNCTIONS =====================================================*/ | |
60 /* | |
61 +------------------------------------------------------------------------------ | |
62 | Function : meas_c_calc_mean | |
63 +------------------------------------------------------------------------------ | |
64 | Description : This function calculates the mean of the received signal level | |
65 | of the four normal bursts that compose a block. It returns | |
66 | the amount of bursts with valid receibed signal values. | |
67 | | |
68 | Parameters : burst_level - receive signal level of the first valid downlink | |
69 | PDCH radio block | |
70 | radio_freq - radio frequency of TDMA frame within a | |
71 | radio block | |
72 | ss_block - mean of the received signal level | |
73 | pb_rdc - Pb reduction | |
74 | | |
75 +------------------------------------------------------------------------------ | |
76 */ | |
77 GLOBAL UBYTE meas_c_calc_mean ( UBYTE *burst_level, | |
78 USHORT *radio_freq, | |
79 ULONG *ss_block, | |
80 UBYTE *pb_rdc, | |
81 T_CGRLC_freq_param *freq_param ) | |
82 { | |
83 UBYTE i; /* used for counting */ | |
84 UBYTE vld_smpl = 0; /* valid measurement samples */ | |
85 | |
86 TRACE_FUNCTION( "meas_c_calc_mean" ); | |
87 | |
88 *pb_rdc = 0; | |
89 *ss_block = 0; | |
90 | |
91 /* add up all measurement data */ | |
92 for( i = 0; i < MAC_BURST_PER_BLOCK; i++ ) | |
93 { | |
94 if( burst_level[i] NEQ MAC_RXLEV_NONE ) | |
95 { | |
96 vld_smpl++; | |
97 | |
98 *ss_block += burst_level[i]; | |
99 | |
100 if( !( grlc_data->tm.freq_param.pdch_hopping EQ FALSE AND | |
101 grlc_data->tm.freq_param.bcch_arfcn EQ radio_freq[i] ) ) | |
102 { | |
103 *pb_rdc += 1; | |
104 } | |
105 } | |
106 } | |
107 | |
108 /* calculate the mean */ | |
109 if( vld_smpl ) | |
110 { | |
111 *ss_block = ( *ss_block * MEAS_ACRCY ) / vld_smpl; | |
112 } | |
113 | |
114 return( vld_smpl ); | |
115 } /* meas_c_calc_mean() */ | |
116 | |
117 /* | |
118 +------------------------------------------------------------------------------ | |
119 | Function : meas_int_fill_rel_iLevel | |
120 +------------------------------------------------------------------------------ | |
121 | Description : ... | |
122 | | |
123 | Parameters : ... | |
124 | | |
125 +------------------------------------------------------------------------------ | |
126 */ | |
127 GLOBAL void meas_int_fill_rel_iLevel ( UBYTE *v_ilev, | |
128 UBYTE *ilev, | |
129 UBYTE idx, | |
130 USHORT c_raw_data_lev ) | |
131 { | |
132 UBYTE val; /* holds interference level data */ | |
133 | |
134 if( grlc_data->meas.ilev.ilev[idx] NEQ CGRLC_ILEV_NONE ) | |
135 { | |
136 if( c_raw_data_lev < grlc_data->meas.ilev.ilev[idx] * MEAS_ACRCY ) | |
137 { | |
138 *ilev = I_LEVEL_MIN; | |
139 } | |
140 else | |
141 { | |
142 val = ( c_raw_data_lev - grlc_data->meas.ilev.ilev[idx] * MEAS_ACRCY ) / | |
143 ( 2 * MEAS_ACRCY ) + 1; | |
144 | |
145 if( val > I_LEVEL_MAX ) *ilev = I_LEVEL_MAX; | |
146 else *ilev = val; | |
147 } | |
148 | |
149 *v_ilev = TRUE; | |
150 } | |
151 else | |
152 { | |
153 *v_ilev = FALSE; | |
154 } | |
155 } /* meas_int_fill_rel_iLevel() */ |