FreeCalypso > hg > freecalypso-sw
diff gsm-fw/g23m-aci/aci/aci_bat_err.c @ 775:eedbf248bac0
gsm-fw/g23m-aci subtree: initial import from LoCosto source
author | Michael Spacefalcon <msokolov@ivan.Harhan.ORG> |
---|---|
date | Sun, 12 Oct 2014 01:45:14 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gsm-fw/g23m-aci/aci/aci_bat_err.c Sun Oct 12 01:45:14 2014 +0000 @@ -0,0 +1,173 @@ +/* ++----------------------------------------------------------------------------- +| Project : GSM-F&D (8411) +| Modul : ACI_BAT ++----------------------------------------------------------------------------- +| 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 : Handle cme and cms errors for BAT clients ++----------------------------------------------------------------------------- +*/ +#include "aci_all.h" + +#include "aci_cmh.h" /* so see T_ACI_ERR_CLASS and other */ +#include "psa.h" +#include "cmh.h" /* extern definition of aciErrDesc */ + +#include "aci_bat_cmh.h" +#include "aci_bat.h" +#include "aci_bat_err.h" + +#include "psa_psi.h" + + +/* + * the [stq]AT_xxx function will set the global variable aciErrDesc with ACI_ERR_DESC. + * here we read it and cast it to the BAT value defined in + * T_BAT_plus_cme_error_error and T_BAT_plus_cms_error_err. + * Currently (03.March 2005) the error values of ACI and BAT are identical, + * but can cause a lot of problems when there is a mismatch! + * There should be used only the values of p_bat.h defined in bat.sap ! + * + * on ACI level there are CME, CMS, CEER and EXT error values. + * CEER errors are/is only one in + * cmh_ccf.c:2159: ACI_ERR_DESC( ACI_ERR_CLASS_Ceer, CAUSE_MAKE(DEFBY_STD, + * and must be requested with the + * T_BAT_cmd_send send.ctrl_params = BAT_CMD_SET_PLUS_CEER by the apllication. + * BAT returns with a T_BAT_res_set_plus_ceer structure. + * + */ + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_BAT | +| STATE : code ROUTINE : aci_bat_err | ++--------------------------------------------------------------------+ + + PURPOSE : central BAT error function called by aci_bat_wrapper only. + it evaluates the global varaible aciErrDesc, which has been set + with the appropriate error value of the just ran ACI function. +*/ +GLOBAL void aci_bat_err (T_ACI_DTI_PRC_PSI *src_infos_psi) +{ + T_ACI_ERR_CLASS err_class; + T_BAT_res_plus_cme_error cme_data; + T_BAT_res_plus_cms_error cms_data; + T_BAT_res_plus_ext_error ext_data; + T_BAT_cmd_response resp; + + if (ACI_BAT_VALID_ERR_DESC()) + { + err_class = (T_ACI_ERR_CLASS)ACI_BAT_GET_ERR_CLASS(); + switch (err_class) + { + case (ACI_ERR_CLASS_Cme): + { + T_BAT_plus_cme_error_error bat_err; + T_ACI_CME_ERR err = (T_ACI_CME_ERR)ACI_BAT_GET_ERR_VALUE(); + ACI_BAT_RESET_ERR_DESC(); + bat_err = (T_BAT_plus_cme_error_error)err; + resp.ctrl_response = BAT_RES_PLUS_CME_ERROR; + resp.response.ptr_plus_cme_error=&cme_data; + resp.response.ptr_plus_cme_error->error = bat_err; + TRACE_EVENT_P1("aci_bat_err(): CME ERROR: %d", bat_err); + break; + } + case (ACI_ERR_CLASS_Cms): + { + T_BAT_plus_cms_error_err bat_err; + T_ACI_CMS_ERR err = (T_ACI_CMS_ERR)ACI_BAT_GET_ERR_VALUE(); + ACI_BAT_RESET_ERR_DESC(); + bat_err = (T_BAT_plus_cms_error_err)err; + resp.ctrl_response = BAT_RES_PLUS_CMS_ERROR; + resp.response.ptr_plus_cms_error=&cms_data; + resp.response.ptr_plus_cms_error->err = bat_err; + TRACE_EVENT_P1("aci_bat_err(): CMS ERROR: %d", bat_err); + break; + } + case (ACI_ERR_CLASS_Ext): + { + T_BAT_plus_ext_error_err bat_err; + T_ACI_EXT_ERR err = (T_ACI_EXT_ERR)ACI_BAT_GET_ERR_VALUE(); + ACI_BAT_RESET_ERR_DESC(); + bat_err = (T_BAT_plus_ext_error_err)err; + resp.ctrl_response = BAT_RES_PLUS_EXT_ERROR; + resp.response.ptr_plus_ext_error=&ext_data; + resp.response.ptr_plus_ext_error->err = bat_err; + TRACE_EVENT_P1("aci_bat_err(): EXT ERROR: %d", bat_err); + break; + } + case (ACI_ERR_CLASS_NotPresent): + default: + /* this should trigger to request the CEER errors by the application */ + resp.ctrl_response = BAT_RES_PLUS_CME_ERROR; + resp.response.ptr_plus_cms_error=&cms_data; + resp.response.ptr_plus_cms_error->err=(T_BAT_plus_cms_error_err)BAT_CME_ERROR_UNKNOWN; + TRACE_EVENT("aci_bat_err(): UNKNOWN ERROR"); + break; + } + } + else + { + TRACE_EVENT("aci_bat_err(): WARNING, no error value set!"); + + resp.ctrl_response = BAT_RES_PLUS_CME_ERROR; + resp.response.ptr_plus_cme_error=&cme_data; + resp.response.ptr_plus_cme_error->error=BAT_CME_ERROR_UNKNOWN; + } + + aci_bat_send(src_infos_psi,&resp); +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_BAT | +| STATE : code ROUTINE : sBAT_PlusCEER | ++--------------------------------------------------------------------+ + + PURPOSE : +*/ +GLOBAL T_ACI_BAT_RSLT sBAT_PlusCEER (T_ACI_DTI_PRC_PSI *src_infos_psi, + T_BAT_cmd_send *cmd) +{ + T_ACI_BAT_RSLT ret; + USHORT cause; + + TRACE_FUNCTION ("sBAT_PlusCEER()"); + + /* + * Call the corresponding ACI function. T_ACI_BAT_RSLT is + * assumed to be equivalent to T_ACI_RESULT. + */ + ret=(T_ACI_BAT_RSLT)qAT_PlusCEER((T_ACI_CMD_SRC)src_infos_psi->srcId,&cause); + + /* + * If the query completes - and it should - send the response now. + */ + if (ret==ACI_BAT_CMPL) + { + T_BAT_cmd_response resp; + T_BAT_res_set_plus_ceer ceer_data; + + resp.ctrl_response=BAT_RES_SET_PLUS_CEER; + resp.response.ptr_set_plus_ceer=&ceer_data; + + ceer_data.definedby=(T_BAT_plus_ceer_definedby)GET_CAUSE_DEFBY(cause); + ceer_data.originatingside=(T_BAT_plus_ceer_originatingside)GET_CAUSE_ORIGSIDE(cause); + ceer_data.originatingentity=(T_BAT_plus_ceer_originatingentity)GET_CAUSE_ORIGIN_ENTITY(cause); + ceer_data.causevalue=(U8)GET_CAUSE_VALUE(cause); + + aci_bat_send(src_infos_psi,&resp); + } + + return(ret); +}