FreeCalypso > hg > freecalypso-sw
comparison gsm-fw/g23m-gsm/ss/ss_em.h @ 673:2f7df7a314f8
gsm-fw/g23m-gsm subtree: initial import from LoCosto source
author | Michael Spacefalcon <msokolov@ivan.Harhan.ORG> |
---|---|
date | Sun, 28 Sep 2014 23:20:04 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
672:0dc6f9e8e980 | 673:2f7df7a314f8 |
---|---|
1 /* | |
2 +----------------------------------------------------------------------------- | |
3 | Project : | |
4 | Modul : | |
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 : Engineering Mode (EM) Declarations + Macros | |
18 | | |
19 +----------------------------------------------------------------------------- | |
20 */ | |
21 #ifndef SS_EM_H | |
22 #define SS_EM_H | |
23 | |
24 #ifdef FF_EM_MODE | |
25 | |
26 | |
27 /* | |
28 * Ring buffer is by one bigger than max. number of prims, because it | |
29 * needs always one termination entry. | |
30 * To optimize the buffersize, the data is packed in the buffer as follows: | |
31 * type, length, value | |
32 * Value is the combination of the additional parameters as defined in 8443.601, coded as UBYTE. | |
33 */ | |
34 #define EM_SS_BUFFER_SIZE 31 | |
35 | |
36 /* | |
37 * EM_MAX_SS_EVENTS defines maximum number of event traces for the engineering mode. | |
38 * The number is increased by one to ensure that the event numbers defined in the | |
39 * corresponding document are the same as in the sources. | |
40 */ | |
41 #define EM_MAX_SS_EVENTS 11 | |
42 | |
43 /* | |
44 * The offset is used to indicate the source entity the event trace is from. | |
45 * L1/ALR = 0x00, DL = 0x2D, RR = 0x37, MM = 0x5F, CC = 0x78, SS = 0xAF, SMS = 0xBE, SIM = E1 | |
46 */ | |
47 #define SS_OFFSET 0xAF | |
48 | |
49 /* | |
50 * Type is combination of entity index(upper nibble) plus event number(lower nibble). | |
51 * Bit 8 7 6 5 4 3 2 1 | |
52 * | entity | event number | | |
53 */ | |
54 #define SS_V_1 (1 + SS_OFFSET) | |
55 #define SS_V_2 (2 + SS_OFFSET) | |
56 #define SS_V_3 (3 + SS_OFFSET) | |
57 #define SS_V_4 (4 + SS_OFFSET) | |
58 #define SS_V_5 (5 + SS_OFFSET) | |
59 #define SS_V_6 (6 + SS_OFFSET) | |
60 #define SS_V_7 (7 + SS_OFFSET) | |
61 #define SS_V_8 (8 + SS_OFFSET) | |
62 #define SS_V_9 (9 + SS_OFFSET) | |
63 #define SS_V_10 (10+ SS_OFFSET) | |
64 | |
65 /* Event tracing flags for EM */ | |
66 EXTERN BOOL ss_v[EM_MAX_SS_EVENTS]; | |
67 | |
68 | |
69 /* -- Functions ----*/ | |
70 /* | |
71 * suppl. services primitives Engineering Mode | |
72 * Bitmask for the event tracing | |
73 */ | |
74 | |
75 EXTERN void ss_em_ss_event_req (T_EM_SS_EVENT_REQ *em_ss_event_req); | |
76 GLOBAL void em_init_ss_event_trace (void); | |
77 | |
78 /* | |
79 * If all entities are linked into one module this definitions | |
80 * prefixes all this functions with the enity name | |
81 */ | |
82 #ifdef OPTION_MULTITHREAD | |
83 #define em_write_buffer_3 _ENTITY_PREFIXED(em_write_buffer_3) | |
84 #define check_write_index _ENTITY_PREFIXED(check_write_index) | |
85 #endif | |
86 | |
87 EXTERN UBYTE em_write_buffer_3 (UBYTE event_no, UBYTE value); | |
88 EXTERN UBYTE check_write_index (UBYTE n); | |
89 | |
90 /*---------------Event Macros ----------*/ | |
91 | |
92 #define MM_EM_MM_CONNECTION_STARTED\ | |
93 /* MM connection started */\ | |
94 if (ss_v[1])\ | |
95 {\ | |
96 ss_v[1] = em_write_buffer_3 (SS_V_1 , ss_data->ti);\ | |
97 } /* ss_v[1] */ | |
98 | |
99 #define MM_EM_MM_CONNECTION_ESTABLISHED\ | |
100 /* MM connection established */\ | |
101 if (ss_v[2])\ | |
102 {\ | |
103 ss_v[2] = em_write_buffer_3 (SS_V_2 , ss_data->ti);\ | |
104 } /* ss_v[2] */ | |
105 | |
106 #define MM_EM_MM_CONNECTION_FAILED\ | |
107 /* MM connection failed */\ | |
108 if (ss_v[3])\ | |
109 {\ | |
110 ss_v[3] = em_write_buffer_3 (SS_V_3 , ss_data->ti);\ | |
111 } /* ss_v[3] */ | |
112 | |
113 #define MM_EM_MM_CONNECTION_ABORTED\ | |
114 /* MM connection aborted */\ | |
115 if (ss_v[4])\ | |
116 {\ | |
117 ss_v[4] = em_write_buffer_3 (SS_V_4 , ss_data->ti);\ | |
118 } /* ss_v[4] */ | |
119 | |
120 #define MM_EM_MM_CONNECTION_RELEASED\ | |
121 /* MM connection released */\ | |
122 if (ss_v[5])\ | |
123 {\ | |
124 ss_v[5] = em_write_buffer_3 (SS_V_5 , ss_data->ti);\ | |
125 } /* ss_v[5] */ | |
126 | |
127 #define MM_EM_REGISTER_MESSAGE_RECEIVED\ | |
128 /* Register message received */\ | |
129 if (ss_v[6])\ | |
130 {\ | |
131 ss_v[6] = em_write_buffer_3 (SS_V_6 , ss_data->ti);\ | |
132 } /* ss_v[6] */ | |
133 | |
134 | |
135 #define MM_EM_FACILITY_MESSAGE_SENT\ | |
136 /* Facility message send */\ | |
137 if (ss_v[7])\ | |
138 {\ | |
139 ss_v[7] = em_write_buffer_3 (SS_V_7 , ss_data->ti);\ | |
140 } /* ss_v[7] */ | |
141 | |
142 #define MM_EM_FACILITY_MESSAGE_RECEIVED\ | |
143 /* Facility message received */\ | |
144 if (ss_v[8])\ | |
145 {\ | |
146 ss_v[8] = em_write_buffer_3 (SS_V_8 , ss_data->ti);\ | |
147 } /* ss_v[8] */ | |
148 | |
149 #define MM_EM_MM_RELEASE_COMPLETE_SENT\ | |
150 /* Release complete sent */\ | |
151 if (ss_v[9])\ | |
152 {\ | |
153 ss_v[9] = em_write_buffer_3 (SS_V_9 , ss_data->ti);\ | |
154 } /* ss_v[9] */ | |
155 | |
156 #define MM_EM_MM_RELEASE_COMPLETE_RECEIVED\ | |
157 /* Release complete received */\ | |
158 if (ss_v[10])\ | |
159 {\ | |
160 ss_v[10] = em_write_buffer_3 (SS_V_10, ss_data->ti);\ | |
161 } /* ss_v[10] */ | |
162 | |
163 #else /*FF_EM_MODE not defined*/ | |
164 | |
165 #define MM_EM_MM_CONNECTION_STARTED /*Event 1*/ | |
166 #define MM_EM_MM_CONNECTION_ESTABLISHED /*Event 2*/ | |
167 #define MM_EM_MM_CONNECTION_FAILED /*Event 3*/ | |
168 #define MM_EM_MM_CONNECTION_ABORTED /*Event 4*/ | |
169 #define MM_EM_MM_CONNECTION_RELEASED /*Event 5*/ | |
170 #define MM_EM_REGISTER_MESSAGE_RECEIVED /*Event 6*/ | |
171 #define MM_EM_FACILITY_MESSAGE_SENT /*Event 7*/ | |
172 #define MM_EM_FACILITY_MESSAGE_RECEIVED /*Event 8*/ | |
173 #define MM_EM_MM_RELEASE_COMPLETE_SENT /*Event 9*/ | |
174 #define MM_EM_MM_RELEASE_COMPLETE_RECEIVED /*Event 10*/ | |
175 | |
176 | |
177 #endif /*FF_EM_MODE*/ | |
178 #endif /* SS_EM_H */ |