FreeCalypso > hg > fc-selenite
diff src/g23m-fad/l2r/tra_dnp.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 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/g23m-fad/l2r/tra_dnp.c Sun Jul 15 04:40:46 2018 +0000 @@ -0,0 +1,217 @@ +/* ++----------------------------------------------------------------------------- +| Project : CSD (8411) +| Modul : tra_dnp.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 : This Modul defines the functions for processing +| of incomming primitives for the component TRA ++----------------------------------------------------------------------------- +*/ + +#ifndef TRA_DNP_C +#define TRA_DNP_C +#endif + +#define ENTITY_L2R + +/*==== INCLUDES ===================================================*/ + +#include <string.h> + +#include "typedefs.h" +#include "pconst.cdg" +#include "vsi.h" +#include "macdef.h" +#include "custom.h" +#include "gsm.h" +#include "prim.h" +#include "pei.h" +#include "tok.h" +#include "dti.h" + +#include "cl_ribu.h" +#include "tra_pei.h" +#include "tra.h" + +/*==== CONST =======================================================*/ + +/*==== TYPES =======================================================*/ + +/*==== VAR EXPORT ==================================================*/ + +/*==== VAR LOCAL ===================================================*/ + +/*==== FUNCTIONS ===================================================*/ + +/* ++------------------------------------------------------------------------------ +| Function : sig_dti_tra_dn_tx_buffer_ready_ind ++------------------------------------------------------------------------------ +| Description : Process signal DTI_REASON_TX_BUFFER_READY received from +| dti library callback function. +| +| Parameters : - +| +| Return : - ++------------------------------------------------------------------------------ +*/ +GLOBAL void sig_dti_tra_dn_tx_buffer_ready_ind() +{ + TRACE_FUNCTION ("sig_dti_tra_dn_tx_buffer_ready_ind()"); + + if (tra_data->dn.Brk_dti_data_ind NEQ NULL) + { + /* + * if there is a pending break indication to be sent via DTI, + * send it now + */ + sig_any_tra_dn_send_break_req(); + return; + } + + switch (GET_STATE (DN)) + { + case DN_IDLE: + { + SET_STATE (DN, DN_WAIT); + break; + } + case DN_SEND: + { + if (dl_send_data_ind()) + { + SET_STATE (DN, DN_IDLE); + } + break; + } + } +} + +/* ++------------------------------------------------------------------------------ +| Function : sig_dti_tra_dn_tx_buffer_full_ind ++------------------------------------------------------------------------------ +| Description : Process signal DTI_REASON_TX_BUFFER_FULL received from +| dti library callback function. +| +| Parameters : - +| +| Return : - ++------------------------------------------------------------------------------ + + The buffer function of DTILIB is not used. + So there is nothing to be done here yet... + +*/ + +GLOBAL void sig_dti_tra_dn_tx_buffer_full_ind() +{ + TRACE_FUNCTION ("sig_dti_tra_dn_tx_buffer_full_ind()"); +} + + +/* ++------------------------------------------------------------------------------ +| Function : rcv_ra_data_ind ++------------------------------------------------------------------------------ +| Description : Process primitive RA_DATA_IND received from RA. +| This function is called if the primitive RA_DATA_IND is +| received or from the signal processing in l2r_pei (tra). +| +| Parameters : ra_data_ind - +| +| +| Return : - ++------------------------------------------------------------------------------ +*/ + +GLOBAL void rcv_ra_data_ind(T_RA_DATA_IND *ra_data_ind) +{ + T_TRA_DN *ddl = &tra_data->dn; + T_FD *pFD = NULL; + + TRACE_FUNCTION("rcv_ra_data_ind()"); + + if (GET_STATE (MGT) NEQ MGT_IDLE) + { + TRACE_EVENT ("data rcvd while not in state MGT_IDLE"); + + while (cl_ribu_data_avail(ddl->ribu)) + { + cl_ribu_get(ddl->ribu); + } + +#ifdef _SIMULATION_ + PFREE (ra_data_ind); +#endif + return; + } + +#ifdef _SIMULATION_ + PACCESS (ra_data_ind); + if (ra_data_ind->sdu.l_buf) + { + pFD = tra_get_next_FrameDesc(); + TRACE_EVENT_P2("put - wi=%d - ri=%d", ddl->ribu->idx.wi, ddl->ribu->idx.ri); + memcpy(pFD->buf, ra_data_ind->sdu.buf, ra_data_ind->sdu.l_buf >> 3); + pFD->len = ra_data_ind->sdu.l_buf >> 3; + } +#endif + + ddl->sa = 0; + ddl->sb = 0; + ddl->x = 0; + + if (ra_data_ind->status & ST_SA) + ddl->sa = DTI_SA_OFF; + if (ra_data_ind->status & ST_SB) + ddl->sb = DTI_SB_OFF; + if (ra_data_ind->status & ST_X) + ddl->x = DTI_FLOW_OFF; + + if (ddl->ribu->idx.filled > 1) + TRACE_EVENT_P3("RIBU ddl: filled=%d; wi=%d; ri=%d", ddl->ribu->idx.filled, ddl->ribu->idx.wi, ddl->ribu->idx.ri); + + while (cl_ribu_data_avail(ddl->ribu)) + { + pFD = cl_ribu_get(ddl->ribu); + dl_prep_data_ind(pFD); + } + + switch (GET_STATE (DN)) + { + case DN_SEND: + break; + + case DN_IDLE: + if (pFD NEQ NULL) + { + SET_STATE (DN, DN_SEND); + } + break; + + case DN_WAIT: + if (dl_send_data_ind()) + { + SET_STATE (DN, DN_IDLE); + } + break; + + default: + break; + } +#ifdef _SIMULATION_ + PFREE (ra_data_ind); +#endif +}