FreeCalypso > hg > freecalypso-sw
diff gsm-fw/ccd/ccd_elem.c @ 648:970d6199f2c5
gsm-fw/ccd/*.[ch]: initial import from the LoCosto source
author | Michael Spacefalcon <msokolov@ivan.Harhan.ORG> |
---|---|
date | Thu, 04 Sep 2014 05:48:57 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gsm-fw/ccd/ccd_elem.c Thu Sep 04 05:48:57 2014 +0000 @@ -0,0 +1,335 @@ +/* ++----------------------------------------------------------------------------- +| Project : +| Modul : ccd_elem.c ++----------------------------------------------------------------------------- +| 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 : Condat Conder Decoder - +| Definition of encoding and decoding functions of +| information elements of air interface messages ++----------------------------------------------------------------------------- +*/ + +#define CCD_ELEM_C + +#include <stdio.h> +#include <string.h> + +#include "typedefs.h" +#include "ccd_globs.h" +#include "ccd.h" +#include "ccdtable.h" +#include "ccddata.h" +#include "ccdapi.h" +#include "bitfun.h" + +#ifndef RUN_INT_RAM +/* ++--------------------------------------------------------------------+ +| PROJECT : CCD (6144) MODULE : ccd_elem | +| STATE : code ROUTINE : ccd_decodeElem | ++--------------------------------------------------------------------+ + + PARAMETERS: ULONG ccdid + - Enumeration of the information element to be + decoded in the file ccdid.h. This number is also + the reference number of the IE in the melem table. + + USHORT l_buf + - Number of bits in the encoded IE. + + USHORT o_buf + - Offset of the bitstream buffer in bits. + + U8 *buf + - Bitstream buffer of the encoded IE. + + U8 *eStruct + - reference to the C-Structure containing the + C-Representation of the decoded IE. + + PURPOSE: decodes a bitstream containing an encoded information + element. The results are written to a corresponding + C-Structure, the C-Representation of the IE. +*/ +int CCDDATA_PREF(ccd_decodeElem) (ULONG ccdid, + USHORT l_buf, + USHORT o_buf, + UCHAR* buf, + UCHAR* eStruct) +{ + int jmp_ret; + USHORT mcompRef; + T_CCD_Globs *globs; + T_CCD_ERR_LIST_HEAD* eentry; + T_CCD_STORE_LIST* stoentry; + + globs = ccd_GetGlobVars (&eentry, &stoentry); + +#ifdef DEBUG_CCD + ccd_dump_msg(l_buf, o_buf, buf, globs); +#endif + + /* + * setup the structure-buffer. */ + globs->pstruct = eStruct; + globs->pstructOffs = 0; + + ccd_common_decode_init(l_buf, o_buf, buf, globs); + ccd_err_reset (eentry); + globs->ccd_recurs_level =1; + + if ((mcompRef = melem[ccdid].elemRef) EQ NO_REF) + { + ccd_recordFault (globs, ERR_INVALID_CCDID, BREAK, ccdid, NULL); + ccd_FreeGlobVars (globs); + ccd_err_free (eentry); + return (BYTE)globs->CCD_Error; + } + + +#ifdef DEBUG_CCD +#ifdef CCD_SYMBOLS + TRACE_CCD (globs, "CCD decode: Element = %s", + mcomp[mcompRef].name); +#else + TRACE_CCD (globs, "CCD decode: CCD_Id = %x", ccdid); +#endif +#endif + +#ifdef ERR_TRC_STK_CCD + /* save the value for tracing in error case */ + globs->error_stack[0] = mcompRef; +#endif /* ERR_TRC_STK_CCD */ + +/* + * Clean up the entite C-structure before decoding. + * Do not overwrite the MsgId (1. Byte) + */ +#ifdef DEBUG_CCD + TRACE_CCD (globs, "CCD Cleaning struct %ld bytes", + mcomp[mcompRef].cSize); +#endif + memset ((UBYTE *) globs->pstruct, 0, + (size_t)(mcomp[mcompRef].cSize)); + + /* + * clear the UPN stack + */ + globs->SP=0; + globs->StackOvfl=FALSE; + globs->KeepReg[0] = 0; + + /* + * inform the GSM-CODEC about the begin of a new message + */ + cdc_GSM_start (globs); + + jmp_ret = setjmp (globs->jmp_mark); + + if (jmp_ret EQ 0) + { + globs->jmp_mark_set = TRUE; + ccd_decodeComposition ((ULONG) mcompRef, globs); + } + +#ifdef DEBUG_CCD + TRACE_CCD (globs, "CCD-ERROR = %d", globs->CCD_Error); + TRACE_CCD (globs, "-------------------------------------------------"); +#endif /* DEBUG_CCD */ + + ccd_FreeGlobVars (globs); + ccd_err_free (eentry); + + return (BYTE) globs->CCD_Error; +} +#endif /* !RUN_INT_RAM */ + +#ifndef RUN_INT_RAM +/* ++--------------------------------------------------------------------+ +| PROJECT : CCD (6144) MODULE : ccd_elem | +| STATE : code ROUTINE : ccd_encodeElem | ++--------------------------------------------------------------------+ + + PARAMETERS: ULONG ccdid + - Enumeration of the information element to be + encoded in the file ccdid.h. This number is also + the reference number of the IE in the melem table + + USHORT l_buf + - Number of bits in the encoded IE. + + USHORT o_buf + - Offset of the bitstream buffer in bits. + + U8 *buf + - Bitstream buffer of the encoded IE. + + UBYTE * eStruct + - reference to the C-Structure containing the + C-Representation of the decoded IE. + + PURPOSE: encodes a C-Structure containing the C-Representation of + an information element to a bitstream. +*/ +int CCDDATA_PREF(ccd_encodeElem) (ULONG ccdid, + USHORT* l_buf, + USHORT o_buf, + UCHAR* buf, + UCHAR* eStruct) +{ + int jmp_ret; + USHORT maxBytes, mcompRef; + T_CCD_Globs *globs; + T_CCD_ERR_LIST_HEAD* eentry; + T_CCD_STORE_LIST* stoentry; + + globs = ccd_GetGlobVars (&eentry, &stoentry); + ccd_err_reset (eentry); + +#ifdef DEBUG_CCD + { + /* to avoid the vsprintf if the traces won't appear anyhow */ + ULONG mask; + if (vsi_gettracemask (globs->me, globs->me, &mask) != VSI_ERROR) + { + globs->TraceIt = mask & TC_CCD; + } + } +#endif + + /* + * Set a sign that no call to setjmp() is done. So ccd_setError + * performs no longjmp in case of an error. + */ + globs->jmp_mark_set = FALSE; + + /* Setup the bitbuffer. */ + globs->bitbuf = buf; + globs->bitpos = 0; + + /* Setup the structure-buffer. */ + globs->pstruct = eStruct; + globs->pstructOffs = 0; + + /* Cleanup the read-caches. */ + globs->lastbytepos16 = globs->lastbytepos32 = 0xffff; + + /* Setup the bitoffset. */ + globs->bitoffs = o_buf; + bf_incBitpos (o_buf, globs); + globs->bitbuf[globs->bytepos] = 0; + + globs->CCD_Error = ccdOK; + globs->ccd_recurs_level =1; + + if ((mcompRef = melem[ccdid].elemRef) EQ NO_REF) + { + ccd_recordFault (globs, ERR_INVALID_CCDID, BREAK, ccdid, NULL); + ccd_FreeGlobVars (globs); + ccd_err_free (eentry); + return (BYTE)globs->CCD_Error; + } + +#ifdef DEBUG_CCD +#ifdef CCD_SYMBOLS + TRACE_CCD (globs, "CCD encode: Element = %s", + mcomp[mcompRef].name); +#else + TRACE_CCD (globs, "CCD encode: CCD_Id = %x", ccdid); +#endif +#endif + +#ifdef ERR_TRC_STK_CCD + /* Save the value for tracing in error case. */ + globs->error_stack[0] = mcompRef; +#endif + + maxBytes = (USHORT) (mcomp[mcompRef].bSize+7)>>3; + #ifdef DEBUG_CCD + TRACE_CCD (globs, "-------------------------------------------------"); + TRACE_CCD (globs, "CCD: Code Elem"); + TRACE_CCD (globs, "Cleaning %d bits (%d bytes) of the bitstream", + mcomp[mcompRef].bSize, maxBytes); +#endif + + /* + * Clean up the bit buffer for the encoded message before encoding. + */ + memset ((U8 *) &buf[o_buf>>3], 0, (size_t) maxBytes); + + /* Store the length of ereased buffer to support error handling. */ + globs->buflen = (USHORT) mcomp[mcompRef].bSize; + + /* + * Clear the UPN stack. + */ + globs->SP=0; + globs->StackOvfl=FALSE; + globs->KeepReg[0] = 0; + + /* + * Inform the GSM-CODEC about the begin of a new message. + */ + cdc_GSM_start (globs); + + jmp_ret = setjmp (globs->jmp_mark); + + if (jmp_ret EQ 0) + { + globs->jmp_mark_set = TRUE; + ccd_encodeComposition ((ULONG) mcompRef, globs); + } + + *l_buf = (USHORT)(globs->bitpos - globs->bitoffs); + +#ifdef DEBUG_CCD +{ + int i, j, buflen; + char s[64], c[4]; + + buflen = (*l_buf + o_buf + 7) >> 3; + + TRACE_CCD (globs, "-------------------------------------------------"); + TRACE_CCD (globs, " After ENCODING: lbuf= %d, obuf= %d", *l_buf, o_buf); + TRACE_CCD (globs, " Hex dump of encoded message:"); + + s[0] = '\0'; + for (i = o_buf >> 3; i < buflen; i+=16) + { + for (j = 0; j < 16; j++) + { + if ((i+j) < buflen) + { + sprintf(c, " %02x", buf[i+j]); + strcat (s, c); + } + } + TRACE_CCD (globs, "%s", s); + s[0] = '\0'; + } +} +#endif + +#ifdef DEBUG_CCD + TRACE_CCD (globs, "CCD-ERROR = %d", globs->CCD_Error); + TRACE_CCD (globs, "-------------------------------------------------"); +#endif /* DEBUG_CCD */ + + ccd_FreeGlobVars (globs); + ccd_err_free (eentry); + + return (BYTE) globs->CCD_Error; +} +#endif /* !RUN_INT_RAM */