FreeCalypso > hg > leo2moko-debug
diff g23m/condat/com/include/vdbapi.h @ 0:509db1a7b7b8
initial import: leo2moko-r1
author | Space Falcon <falcon@ivan.Harhan.ORG> |
---|---|
date | Mon, 01 Jun 2015 03:24:05 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/g23m/condat/com/include/vdbapi.h Mon Jun 01 03:24:05 2015 +0000 @@ -0,0 +1,142 @@ +/* ++----------------------------------------------------------------------------- +| Project : GSM-PS (6147) +| Modul : ++----------------------------------------------------------------------------- +| 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 : ++----------------------------------------------------------------------------- +*/ + +#ifndef __VDBAPI_H__ +#define __VDBAPI_H__ + +/* + * @todo anpassen an routing information + */ + +/* + * Number of protocol stack entities witch concurrently uses the VDB + */ +#define VDB_MAX_ENTITIES 8 + +/* + * Identifiers for the protocol stack entities. To use at + * initialisation of the VDB (vdb_init()). + */ +#define VDB_MMI 7 +#define VDB_SIM 6 +#define VDB_SMS 5 +#define VDB_SS 4 +#define VDB_CC 3 +#define VDB_MM 2 +#define VDB_RR 1 +#define VDB_DL 0 + + +/* + * Return codes for the state parameter of the vdb_read_req() + */ +#define VDB_ENTITY_VALID 1 +#define VDB_ENTITY_EMPTY 2 +#define VDB_ENTITY_UNDEF 0 + +/* + * Definition to mark the assi parameter invalid + * for the function vdb_update_req() + */ +#define VDB_INVALID_SSI ((ULONG)-1L) + +/* + * definition of the VDB related part of the destination adress + * fragment of the primitives used in the base station. + */ + +typedef struct +{ + UBYTE vdb_id; + ULONG vdb_handle; + ULONG search_ssi; + ULONG send_ssi; +} T_DEST_ADDR; + + +/* == PROTOTYPES OF THE FUNCTIONAL VDB IMPLEMENTATION ============ */ + +EXTERN BOOL vdb_reset (void); + +EXTERN BOOL vdb_init (UBYTE entity, + UBYTE vdb_id); + +EXTERN void vdb_read_req (T_DEST_ADDR * da, + UBYTE entity, + void **entry, + UBYTE * state); + +EXTERN void vdb_update_req (T_DEST_ADDR * da, + UBYTE entity, + void * entry, + ULONG assi); + +EXTERN void vdb_free_req (T_DEST_ADDR * da, + UBYTE entity); + +EXTERN void vdb_unlock_req (T_DEST_ADDR * da); + +/* == MACRODEFINITION FOR THE VARIOUS REALISATIONS OF THE VDB == */ + +#ifdef VDB_AS_A_MODULE + +#define VDB_READ_REQ(l,d,e,v,s) void * v; UBYTE s; vdb_read_req (d,e,&v,&s) +#define VDB_NET_READ_REQ(l,p,e,v,s) void * v; UBYTE s; NET_TO_DEST(p);\ + vdb_read_req (&dest_addr,e,&v,&s) +#define VDB_UNLOCK_REQ(d) vdb_unlock_req (d); +#define VDB_UPDATE_REQ(d,e,v,a) vdb_update_req (d,e,v,a) +#define VDB_FREE_REQ(d,e) vdb_free_req (d,e); + +#else +#ifdef VDB_AS_A_SERVER +/* + * opcodes may be defined by server stub + */ +#define READ_REQ 1 +#define UPDATE_REQ 2 +#define FREE_REQ 3 + +#define VDB_READ_REQ(l,d,e,v,s) void * v; UCHAR s; vdb (READ_REQ,d,e,&v,&s) +#define VDB_NET_READ_REQ(l,p,e,v,s) void * v; UCHAR s; NET_TO_DEST(p);\ + vdb (READ_REQ,&dest_addr,e,&v,&s) +#define VDB_UNLOCK_REQ(d) vdb (UNLOCK_REQ, d) +#define VDB_UPDATE_REQ(d,e,v,a) vdb (UPDATE_REQ, d,e,v,a) +#define VDB_FREE_REQ(d,e) vdb (FREE_REQ, d,e) + +#else +#ifdef VDB_AS_A_PROCESS +/* + * Not defined yet + */ +#define VDB_READ_REQ(l,d,e,v,s) void l(); send_vdb_read_req (l,d,e); }\ + void l(T_DEST_ADDR * d, void **v, UBYTE *s) { +#define VDB_NET_READ_REQ(l,p,e,v,s) void l(); NET_TO_DEST(p);\ + send_vdb_read_req (l,&dest_addr,e); }\ + void l(T_DEST_ADDR * d, void **v, UBYTE *s) { +#define VDB_UNLOCK_REQ(d) send_vdb_read_req (d) +#define VDB_UPDATE_REQ(d,e,v,a) send_vdb_update_req (d,e,v,a) +#define VDB_FREE_REQ(d,e) send_vdb_free_req (d,e) + +#endif +#endif +#endif + +#endif +