FreeCalypso > hg > fc-tourmaline
diff src/g23m-aci/gdd_dio/gdd.h @ 1:fa8dc04885d8
src/g23m-*: import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:25:50 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/g23m-aci/gdd_dio/gdd.h Fri Oct 16 06:25:50 2020 +0000 @@ -0,0 +1,440 @@ +/* ++----------------------------------------------------------------------------- +| Project : GSM-F&D (8411) +| Modul : BAT library ++----------------------------------------------------------------------------- +| 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 : API of the Generic Data aDapter (GDD) which connects the +| application domain with the protocol stack. ++----------------------------------------------------------------------------- +*/ + +#ifndef GDD_H +#define GDD_H + +/*==== INCLUDES =============================================================*/ + +/*==== DEFINITIONS ==========================================================*/ + +/** Return and error values of GDD functions */ +enum GDD_RESULT_CODES +{ + GDD_OK = 0, /* OK, no error occured */ + GDD_BUSY = 1, /* Currently busy */ + GDD_DIO_NOT_READY = 2, /* Dio not initialized or ready */ + GDD_NO_CONNECTION_SLOT = 3, /* Max number of connections already open */ + GDD_NO_BUF_AVAILABLE = 4, /* No buffer available (for sending) */ + GDD_INVALID_PARAMS = 5, /* Invalid input parameter */ + GDD_REQ_BUF_TOO_LARGE = 6, /* Requested buffer too large */ + GDD_INVALID_BUFFER = 7, /* Invalid buffer */ + GDD_ALREADY_INITIALIZED = 97, /* Instance already initialized */ + GDD_NO_MEMORY = 98, /* Memory allocation during initialization failed */ + GDD_INTERNAL_ERROR = 99 /* General error code for all other errors */ +}; + + +/*==== CONSTS ===============================================================*/ + +/** This size that's required for maintenance of one single connection. + Only needed if the application must allocated memory to be passed into + gdd_init(). */ +#define GDD_DIO_SIZEOF_CONDATA 64 + +/** Size of first buffer segment (used for internal purposes) */ +#define GDD_DIO_PID_SEG_SIZE 2 + + +/*==== TYPES =================================================================*/ + +/** Connection handle */ +typedef U32 T_GDD_CON_HANDLE; + + +/** Identifier for the adapter instances - each instance corresponds to a + DIO driver type */ +typedef enum +{ + GDD_INST_NONE = -1, + GDD_INST_BAT = 0, /* The BAT library */ + GDD_INST_APP, /* Application */ + GDD_INST_TCP, /* TCPIP entity */ + GDD_INST_SOCK, /* Socket library */ + GDD_INST_SOCKCFG, /* Socket library configuration */ + + /* Add new instances here and increase GDD_NUM_INSTS accordingly */ + GDD_NUM_INSTS, + /* Maximum number of instances is defined by GDD_MAX_INST_ID */ + GDD_MAX_INST_ID = 255 +} T_GDD_INST_ID; + + +/* + * GDD data format - identicial to DIOv4 data format. + */ +typedef struct +{ + U8 _align0; /*< 0: 1> alignment */ + U8 _align1; /*< 1: 1> alignment */ + U16 c_data; /*< 2: 2> counter */ + U8 *ptr_data; /*< 4: 4> pointer to pointer to the first + byte of the data buffer segment */ +} T_GDD_SEGMENT; + +typedef struct +{ + U16 length; /*< 0: 2> len of dio_ctrl */ + U8 _align0; /*< 2: 1> alignment */ + U8 c_segment; /*< 3: 1> counter of segments */ + T_GDD_SEGMENT *ptr_gdd_segment; /*< 4: 4> pointer to Structured Element */ +} T_GDD_BUF; + + + +/** Capabilities of DIO BAT adapter, to be set by the client */ +typedef struct +{ + U32 mtu_size; +} T_GDD_DIO_CAP; + + +/** Capabilities of the BAT adapter, to be set by the client */ +typedef union +{ + T_GDD_DIO_CAP dio_cap; + /* Capabilities for future adapter implementations to be added here */ +} T_GDD_CAP; + + +/** GDD result type */ +typedef U16 GDD_RESULT; + + +/** Signal types */ +typedef enum +{ + GDD_SIGTYPE_CONNECTION_OPENED = 1, /* Connection is established and usable */ + GDD_SIGTYPE_CONNECTION_FAILED = 2, /* Connection failed or closed down unexpectedly */ + GDD_SIGTYPE_SEND_BUF_AVAILABLE = 3, /* A new send buffer becomes available after an + unsuccessfull call to gdd_get_send_buffer */ + GDD_SIGTYPE_BUF_SENT = 4 /* Indicates that the last sent buffer has been + successfully sent */ +} T_GDD_SIGTYPE; + + + +/** Data associated with a GDD signal */ +typedef struct +{ + T_GDD_SIGTYPE sig; +} T_GDD_SIGNAL; + + + +/*************************************************************************** + * Call-back function definitions (to be implemented by the client) + ***************************************************************************/ + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_signal_cb ++------------------------------------------------------------------------------ +| Description : The adapter calls this call-back function to send received data +| to the client. The client must copy the data contained in the +| buffer, since the buffer will be invalidated upon returning +| from this function. +| Alternatively, the client can indicate that he is currently +| busy. In this case, he has to call gdd_signal_ready_rcv() at a +| later time to invoke this call-back function again. +| +| Parameters : sig - Signal ++------------------------------------------------------------------------------ +*/ +typedef void (* T_GDD_SIGNAL_CB) +( T_GDD_CON_HANDLE con, + T_GDD_SIGNAL sig ); + +/* ++------------------------------------------------------------------------------ +| Function : gdd_received_data_cb ++------------------------------------------------------------------------------ +| Description : The adapter calls this callback function to signal events to +| the client. +| +| Parameters : sig - Signal +| +| Return : GDD_OK - Data was copied by client +| GDD_BUSY - Client was busy and could not receive data. ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_RECEIVE_DATA_CB) +( T_GDD_CON_HANDLE con, + T_GDD_BUF * buf ); + + +/*************************************************************************** + * Function definitions + ***************************************************************************/ + +/* ++------------------------------------------------------------------------------ +| Function : gdd_init ++------------------------------------------------------------------------------ +| Description : This optional function can be used to provide the house-keeping +| memory required for the given adapter instance. On platforms +| where memory allocation is available, the function might be +| called with the parameter mem set to 0. In this case, it is +| just use to limit the number of connections via the parameter +| num_con. +| +| Parameters : inst - Instance identifier of the adapter +| mem - Memory allocated by client for maintenance +| of the connections (Input parameter). +| If set to 0, the adapter will allocate +| the memory itself. +| num_con - Maximum number of connections +| +| Return : GDD_OK - Initialization successful +| >GDD_OK - Error (see manual for error codes) ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_INIT) +( T_GDD_INST_ID inst, + void * mem, + U16 num_con); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_deinit ++------------------------------------------------------------------------------ +| Description : This function de-initializes an adapter instance. +| Any memory that the adapter has allocated internally is freed. +| +| Parameters : inst - Instance identifier of the adapter +| +| Return : GDD_OK - Initialization successful +| >GDD_OK - Error (see manual for error codes) ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_DEINIT) +( T_GDD_INST_ID inst); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_connect ++------------------------------------------------------------------------------ +| Description : This function prepares a new connection for data transmission. +| If the function succeeds, it will return a connection handle +| in the parameter 'con_handle' to the caller. Each connection is +| uniquely identified by its connection handle. +| +| Note : The connection cannot be used straight away. Instead, the +| client receives a signal GDD_SIGTYPE_CONNECTION_OPENED when the +| connection setup has been finished. +| +| Each open connection should be closed using the function +| gdd_close() when it is not used any longer. +| +| Parameters : inst - Instance identifier of the adapter +| con_handle - New handle to the adapter passed back to the +| caller (output parameter). +| cap - capabilities of the adapter +| rcv_cb - Call-back for receiving data (provided by client) +| sig_cb - Call-back for signals (provided by client) +| +| Return : GDD_OK - Connecting is setup and being created. The client +| has to wait for signal GDD_SIGTYPE_CONNECTION_OPENED +| before the connection is usable. +| >GDD_OK - Error (see manual for error codes) ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_CONNECT) +( T_GDD_INST_ID inst, + T_GDD_CON_HANDLE * con_handle, + const T_GDD_CAP * cap, + T_GDD_RECEIVE_DATA_CB rcv_cb, + T_GDD_SIGNAL_CB sig_cb ); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_disconnect ++------------------------------------------------------------------------------ +| Description : This function closes and deletes a connection. +| The connection handle will not be valid any longer. +| +| Parameters : con_handle - Handle to the connection to be closed +| +| Return : GDD_OK - Initialization successful +| >GDD_OK - Error (see manual for error codes) ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_DISCONNECT) +( T_GDD_CON_HANDLE con_handle ); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_get_send_buffer ++------------------------------------------------------------------------------ +| Description : This function request a send buffer of a minimum size data_size +| for sending on the connection specified with con. The buffer is +| passed back in the parameter 'buf'. +| After a successful call to this function, it is the +| responsibility of the caller to subsequently fill the buffer +| and call gdd_send_data(), before another call to +| gdd_get_send_buffer() is done. In other words, the client must +| make sure that calls to these two functions are synchronized. +| +| Parameters : con_handle - Connection handle +| buf - Pointer to pointer to send buffer (out parameter) +| data_size - Minimum size of requested buffer +| +| Return : GDD_OK - Initialization successful +| >GDD_OK - Error (see manual for error codes) +| GDD_NO_BUF_AVAILABLE - No buffer available. The client +| will be notified with a signal +| GDD_SIGTYPE_SEND_BUF_AVAILABLE when a +| buffer is ready and can be requested. ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_GET_SEND_BUFFER) +( T_GDD_CON_HANDLE con_handle, + T_GDD_BUF ** buf, + U16 data_size ); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_send_data ++------------------------------------------------------------------------------ +| Description : This functions sends a buffer over the specified connection. +| Please see also description of gdd_get_send_buffer(). +| +| +| Parameters : con_handle - Connection handle +| buf - Buffer to be sent +| +| Return : GDD_OK - Initialization successful +| >GDD_OK - Error (see manual for error codes) +| GDD_INVALID_BUFFER - The buffer pointed to is incorrect, i.e. +| not the one that was previously requested ++------------------------------------------------------------------------------ +*/ +typedef GDD_RESULT (* T_GDD_SEND_DATA) +( T_GDD_CON_HANDLE con, + T_GDD_BUF * buf); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_signal_ready_rcv ++------------------------------------------------------------------------------ +| Description : This function is called from the client to indicate that he +| is ready to receive. Typically, it is called from the client +| when he becomes ready after a preceding result callback +| (result_cb) was returned with GDD_BUSY. +| +| Parameters : con_handle - Connection handle ++------------------------------------------------------------------------------ +*/ +typedef void (* T_GDD_SIGNAL_READY_RCV) +( T_GDD_CON_HANDLE con ); + + +/** GDD Function pointer table */ +typedef struct +{ + T_GDD_INIT gdd_init; + T_GDD_DEINIT gdd_deinit; + T_GDD_CONNECT gdd_connect; + T_GDD_DISCONNECT gdd_disconnect; + T_GDD_GET_SEND_BUFFER gdd_get_send_buffer; + T_GDD_SEND_DATA gdd_send_data; + T_GDD_SIGNAL_READY_RCV gdd_signal_ready_rcv; +} T_GDD_FUNC; + + +/** Needed for initialization of client of BAT adapter (BAT library) */ +extern T_GDD_FUNC gdd_func_dio; + + +/*************************************************************************** + * Helper function definitions + ***************************************************************************/ + +/* ++------------------------------------------------------------------------------ +| Function : gdd_write_buf ++------------------------------------------------------------------------------ +| Description : Write data from a client buffer into into a GDD buffer +| The datagram protocol ID for the following link layer (PPP) is +| set internally to 0x21 (IPv4). If you need to set the protocol +| ID to something else, please use the function +| gdd_write_buf_with_pid().. +| +| Parameters : src_buf - Source buffer (client owned) +| src_size - Size of source buffer +| dest_buf - Destination buffer +| +| Return : 0 if all bytes have been written to the destination buffer. +| If not all bytes could be written, the return value is larger +| than 0 and denotes the number of remaining (unwritten) bytes. +| A negative return value indicates an error. ++------------------------------------------------------------------------------ +*/ +S32 gdd_write_buf(const U8 * src_buf, U16 src_size, T_GDD_BUF * dest_buf); + +/* ++------------------------------------------------------------------------------ +| Description : Write user data and a datagram protocol ID used by the link +| layer (PPP) into a GDD buffer. +| +| Parameters : src_buf - Source buffer (client owned) +| src_size - Size of source buffer +| dest_buf - Destination buffer +| protocol_id - datagram protocol identifier +| +| Return : 0 if all bytes have been written to the destination buffer. +| If not all bytes could be written, the return value is larger +| than 0 and denotes the number of remaining (unwritten) bytes. +| A negative return value indicates an error. ++------------------------------------------------------------------------------ +*/ +S32 gdd_write_buf_with_pid(const U8 * src_buf, U16 src_size, + T_GDD_BUF * dest_buf,U8 protocol_id); + + +/* ++------------------------------------------------------------------------------ +| Function : gdd_read_buf ++------------------------------------------------------------------------------ +| Description : Read data from a GDD buffer into a client buffer. +| +| Parameters : src_buf - Source buffer received from GDD +| dest_buf - Destination buffer (client owned) +| dest_size - Size of destination buffer +| +| Return : 0 if all bytes have been copied into the destination buffer. +| If not all bytes could be copied into the destination buffer, +| the return value is larger than 0 and denotes the number of +| remaining (unread) bytes. A negative return value indicase an +| error. ++------------------------------------------------------------------------------ +*/ +S32 gdd_read_buf(const T_GDD_BUF * src_buf, U8 * dest_buf, U16 dest_size); + + +#endif /* GDD_H */