FreeCalypso > hg > fc-magnetite
view src/g23m-aci/gdd_dio/gdd_dio_drxf.c @ 307:6d1eac845d3e
make it possible to enable SERIAL_DYNAMIC_SWITCH on the configure.sh line
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Thu, 02 Nov 2017 05:49:53 +0000 |
parents | 53929b40109c |
children |
line wrap: on
line source
/* +----------------------------------------------------------------------------- | File : gdd_dio_drxf.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 is part of the entity gdd_dio and implements the | drx service functions. +----------------------------------------------------------------------------- */ #define ENTITY_GDD_DIO /*==== INCLUDES =============================================================*/ #include "typedefs.h" /* to get Condat data types */ #include "vsi.h" /* to get a lot of macros */ /* GDD stuff */ #include "gdd_dio.h" /* to get the global entity definitions */ #include "gdd_dio_data.h" /* to get internal data structures */ #include "gdd_dio_con_mgr.h" #include "gdd_dio_queue.h" #include "gdd_dio_drxf.h" #include "gdd_dio_txf.h" /*==== CONST ================================================================*/ /*==== LOCAL VARS ===========================================================*/ /*==== PRIVATE FUNCTIONS ====================================================*/ /*==== PUBLIC FUNCTIONS =====================================================*/ GLOBAL void gdd_dio_drx_sig_receive_data(T_GDD_CON_HANDLE con_handle, T_dio_buffer * buf) { T_GDD_DIO_CON_DATA * con_data; GDD_RESULT result; TRACE_FUNCTION("[GDD] gdd_dio_drx_sig_receive_data()"); con_data = get_con_data_from_handle(con_handle); result = con_data->rcv_cb(con_handle, (T_GDD_BUF *)buf); if(result EQ GDD_OK) { gdd_dio_send_signal_to_dio(con_data, DRV_SIGTYPE_WRITE); } else { /* Do nothing - the client must come back to use by calling gdd_signal_ready_rcv. */ } } GLOBAL void gdd_dio_drx_ready_to_rcv(T_GDD_CON_HANDLE con_handle) { T_GDD_DIO_CON_DATA * con_data; T_dio_buffer * buf; GDD_RESULT result; TRACE_FUNCTION("[GDD] gdd_dio_drx_ready_to_rcv()"); con_data = get_con_data_from_handle(con_handle); if(gdd_dio_queue_peek_next_for_dequeue(&(con_data->tx_queue), &buf)) { /* Send data to client */ result = con_data->rcv_cb(con_handle, (T_GDD_BUF *)buf); if(result EQ GDD_OK) { gdd_dio_send_signal_to_dio(con_data, DRV_SIGTYPE_WRITE); } else { /* Do nothing - the client must come back again later by calling gdd_signal_ready_rcv. */ } } else { TRACE_ERROR("[GDD] Failed to peek buffer"); } }