FreeCalypso > hg > freecalypso-citrine
diff g23m-gsm/cc/cc_ffk.c @ 0:75a11d740a02
initial import of gsm-fw from freecalypso-sw rev 1033:5ab737ac3ad7
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 09 Jun 2016 00:02:41 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/g23m-gsm/cc/cc_ffk.c Thu Jun 09 00:02:41 2016 +0000 @@ -0,0 +1,498 @@ +/* ++----------------------------------------------------------------------------- +| Project : GSM-PS (6147) +| Modul : CC_FFK ++----------------------------------------------------------------------------- +| 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 Modul defines the functions called by the primitive +| processing functions of the SDL process FORMATTER. ++----------------------------------------------------------------------------- +*/ + +#ifndef CC_FFK_C +#define CC_FFK_C + +#include "config.h" +#include "fixedconf.h" +#include "condat-features.h" + +#define ENTITY_CC +/*==== INCLUDES ===================================================*/ + +#include <string.h> +#include "typedefs.h" +#include "pcm.h" +#include "vsi.h" +#include "custom.h" +#include "gsm.h" +#include "message.h" +#include "ccdapi.h" +#include "prim.h" +#include "cnf_cc.h" +#include "mon_cc.h" +#include "pei.h" +#include "tok.h" +#include "cc.h" + +/*==== EXPORT =====================================================*/ + +/*==== PRIVAT =====================================================*/ + +/*==== VARIABLES ==================================================*/ + +/*==== FUNCTIONS ==================================================*/ +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_called_party_bcd | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a called party bcd information + element. + +*/ + +GLOBAL BOOL for_check_called_party_bcd (UBYTE ton, UBYTE npi) +{ + TRACE_FUNCTION ("for_check_called_party_bcd()"); + + /* + * Check numbering type + */ + if (ton <= M_CC_TON_DEDICATED) + { + /* + * Check numbering plan + */ + switch (npi) + { + case M_CC_NPI_UNKNOWN: + case M_CC_NPI_ISDN: + case M_CC_NPI_X121: + case M_CC_NPI_F69: + case M_CC_NPI_NATIONAL: + case M_CC_NPI_PRIVATE: + return TRUE; + default: + break; + } + } + return FALSE; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_called_party_sub | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a called party sub information + element. + +*/ + +GLOBAL BOOL for_check_called_party_sub (T_M_CC_called_subaddr * called_subaddr) +{ + TRACE_FUNCTION ("for_check_called_party_sub()"); + + switch (called_subaddr->tos) + { + case M_CC_TOS_NSAP: + case M_CC_TOS_USER: + return TRUE; + default: + return FALSE; + } +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_calling_party_bcd| ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a calling party bcd information + element. + +*/ + +GLOBAL BOOL for_check_calling_party_bcd (T_M_CC_calling_num * calling_num) +{ + TRACE_FUNCTION ("for_check_calling_party_bcd()"); + + /* + * Check numbering type + */ + if (calling_num->ton <= M_CC_TON_DEDICATED) + { + /* + * Check numbering plan + */ + switch (calling_num->npi) + { + case M_CC_NPI_UNKNOWN: + case M_CC_NPI_ISDN: + case M_CC_NPI_X121: + case M_CC_NPI_F69: + case M_CC_NPI_NATIONAL: + case M_CC_NPI_PRIVATE: + break; + default: + return FALSE; + } + /* + * Check Present Indicator + */ + if (calling_num->v_present AND + (calling_num->present > M_CC_PRES_NOT_AVAIL)) + return FALSE; + else + return TRUE; + } + return FALSE; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_calling_party_sub | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a calling party sub information + element. + +*/ + +GLOBAL BOOL for_check_calling_party_sub (T_M_CC_calling_subaddr * calling_subaddr) +{ + TRACE_FUNCTION ("for_check_calling_party_sub()"); + + switch (calling_subaddr->tos) + { + case M_CC_TOS_NSAP: + case M_CC_TOS_USER: + return TRUE; + default: + return FALSE; + } +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_callstate | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a callstate information + element. + +*/ + +GLOBAL void for_check_call_state (T_M_CC_call_state * call_state) +{ + TRACE_FUNCTION ("for_check_call_state()"); + + if ( call_state->cs NEQ M_CC_CS_GSM_PLMN ) /* VK 04-jul-97 */ + call_state->state = M_CC_CS_10; /* VK 04-jul-97 */ +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_cc_cause | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a cc cause information + element. + +*/ + +GLOBAL BOOL for_check_cc_cause (T_M_CC_cc_cause* cc_cause) +{ + TRACE_FUNCTION ("for_check_cc_cause()"); +//TISH patch for OMAPS00129223 +#if 0 + /* + * this is a (dirty) "trick" to detect that the cause IE was not present + * although mandatory (for some messages): value 0 is reserved, i.e. it is not + * expected that it will be sent by a network; CCD/the frame ensures that the + * memory contents is 0 which will be seen as value if the cause IE was not present + */ + if (cc_cause->cause EQ 0) + return FALSE; +#endif + /* + * coding standards other than GSM are not supported (which is a valid option); + * map the cause value to interworking, unspecified then, skip further checks + */ + if (cc_cause->cs NEQ M_CC_CS_GSM_PLMN ) + { + cc_cause->cause = M_CC_CAUSE_INTERWORKING; + return TRUE; + } + + /* check for reserved Location (octet 3) */ + switch (cc_cause->loc) + { + case M_CC_LOC_USER: + case M_CC_LOC_PRIV_NET_LOCAL_USER: + case M_CC_LOC_PUB_NET_LOCAL_USER: + case M_CC_LOC_TRANSIT_NET: + case M_CC_LOC_PRIV_NET_REMOTE_USER: + case M_CC_LOC_PUB_NET_REMOTE_USER: + case M_CC_LOC_INTERNATIONAL_NET: + case M_CC_LOC_BEYOND_POINT: + break; + default: + return FALSE; + } + + /* check Recommendation (octet 3a) */ + /* + * the condition below also checks the value of octet 3a (if present); + * this stems from GSM 04.08 of Ph1 were the value 1 was defined as indicating + * GSM; since Ph2 there is the requirement that octet 3a shall not be included + * for coding standard being equal to GSM; however, the design decision is + * to keep the Ph1 behaviour in order to be a "tolerant" MS and to avoid + * interworking problems with Ph1 infrastructure, especially as this case is + * not treated in GSM 09.90 + */ + if (cc_cause->v_rec AND + (cc_cause->rec NEQ 1)) + return FALSE; + else + return TRUE; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_progress_indicator| ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a progress indicator information + element. + +*/ + +GLOBAL BOOL for_check_progress_indicator (T_M_CC_progress * progress) +{ + TRACE_FUNCTION ("for_check_progress_indicator()"); + + /* coding standard and progress description are not in optional octets (3 and 4) */ + if ((progress->v_cs EQ FALSE) OR + (progress->v_progress_desc EQ FALSE)) + return FALSE; + + /* + * map progress description to "Unspecific" if coding standard other than + * GSM is used; note that it is an option to not support coding standards + * other than GSM (which Condat takes) + */ + if (progress->cs NEQ M_CC_CS_GSM_PLMN) + { + progress->progress_desc = MNCC_PROG_UNSPECIFIC; + return TRUE; /* don't care about reserved values for Location anymore of other standards */ + } + + /* check for reserved Location values */ + switch (progress->loc) + { + case M_CC_LOC_USER: + case M_CC_LOC_PRIV_NET_LOCAL_USER: + case M_CC_LOC_PUB_NET_LOCAL_USER: + case M_CC_LOC_PRIV_NET_REMOTE_USER: + case M_CC_LOC_PUB_NET_REMOTE_USER: + case M_CC_LOC_BEYOND_POINT: + break; + default: + return FALSE; + } + + return TRUE; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_repeat_indicator | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a repeat indicator information + element. + +*/ + +GLOBAL BOOL for_check_repeat_indicator (UBYTE repeat) +{ + TRACE_FUNCTION ("for_check_repeat_indicator()"); + + if ((repeat EQ M_CC_REPEAT_CIRCULAR) + OR + (repeat EQ M_CC_REPEAT_SEQUENTIAL) + ) + return TRUE; + else + return FALSE; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_check_signal | ++--------------------------------------------------------------------+ + + PURPOSE : Checks the content of a signal information + element. + +*/ + +GLOBAL BOOL for_check_signal (UBYTE signal) +{ + TRACE_FUNCTION ("for_check_signal()"); + + if ((signal <= M_CC_SIGNAL_HOOK_OFF_ON) + OR + (signal EQ M_CC_SIGNAL_TONES_OFF) + OR + (signal EQ M_CC_SIGNAL_ALERT_OFF)) + return TRUE; + else + return FALSE; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_set_conditional_error | ++--------------------------------------------------------------------+ + + PURPOSE : Stores a detected conditional error. + +*/ + +GLOBAL void for_set_conditional_error (UBYTE iei) +{ + GET_INSTANCE_DATA; + TRACE_FUNCTION ("for_set_conditional_error()"); + + switch (cc_data->error) + { + case M_CC_CAUSE_INFO_ELEM_NOT_IMPLEM: + case M_CC_CAUSE_INVALID_MAND_INFO: + break; + + default: + cc_data->error = M_CC_CAUSE_COND_INFO_ELEM; + if (cc_data->error_count < MAX_ERROR_TAGS) + cc_data->error_inf [cc_data->error_count++] = iei; + break; + } +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_set_mandatory_error | ++--------------------------------------------------------------------+ + + PURPOSE : Stores a detected mandatory error. + +*/ + +GLOBAL void for_set_mandatory_error ( UBYTE iei) +{ + GET_INSTANCE_DATA; + TRACE_FUNCTION ("for_set_mandatory_error()"); + + switch (cc_data->error) + { + case M_CC_CAUSE_INFO_ELEM_NOT_IMPLEM: + case M_CC_CAUSE_COND_INFO_ELEM: + cc_data->error_count = 0; + /*FALLTHROUGH*/ /*lint -fallthrough*/ + + default: + cc_data->error = M_CC_CAUSE_INVALID_MAND_INFO; + if (cc_data->error_count < MAX_ERROR_TAGS) + cc_data->error_inf [cc_data->error_count++] = iei; + break; + } +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CC_FFK | +| STATE : code ROUTINE : for_set_optional_error | ++--------------------------------------------------------------------+ + + PURPOSE : Stores a detected optional error. + +*/ + +GLOBAL void for_set_optional_error ( UBYTE iei) +{ + GET_INSTANCE_DATA; + TRACE_FUNCTION ("for_set_optional_error()"); + + switch (cc_data->error) + { + case M_CC_CAUSE_INVALID_MAND_INFO: + break; + + case M_CC_CAUSE_COND_INFO_ELEM: + cc_data->error_count = 0; + /*FALLTHROUGH*/ /*lint -fallthrough*/ + + default: + /* + * Check whether the iei is compression required + */ + if ((iei & 0xF0) EQ 0) + for_set_mandatory_error (iei); + else + { + cc_data->error = M_CC_CAUSE_INFO_ELEM_NOT_IMPLEM; + if (cc_data->error_count < MAX_ERROR_TAGS) + cc_data->error_inf [cc_data->error_count++] = iei; + } + break; + } +} + +/* ++--------------------------------------------------------------------+ +| | STATE : code ROUTINE : cc_check_critical_error | ++--------------------------------------------------------------------+ + + PURPOSE : This function checks wheter a critical error has been + detected in the air message. Critical errors which prevent + the treatment of an air message are + - invalid Message ID + - mandatory IE missing + - IE coded as comprehension required missing +*/ + +GLOBAL BOOL cc_check_critical_error (UBYTE cc_err) +{ + TRACE_FUNCTION ("cc_check_critical_error ()"); + if (cc_err EQ M_CC_CAUSE_INVALID_MAND_INFO OR + cc_err EQ M_CC_CAUSE_MESSAGE_TYPE_NOT_IMPLEM OR + cc_err EQ M_CC_CAUSE_COND_INFO_ELEM OR + cc_err EQ M_CC_CAUSE_SERVICE_NOT_IMPLEM ) + return (TRUE); + else + return (FALSE); +} + +#endif