Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

wtp_resp_machine.def

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 
00058 /*
00059  * wtp_resp_machine.def - macro call for generating WTP responder statemachine.
00060  * See the architecture document for guidance how to use and update it.
00061  *
00062  * By Aarno Syvänen for Wapit Ltd.
00063  *
00064  * WTPRespMachine data structure includes current state of WTP responder state 
00065  * machine for a specific transaction. This means all data needed to handle at
00066  * least two incoming events of a certain transaction. Its fields can be 
00067  * grouped following way:
00068  *
00069  * General: wtp responder machine state 
00070  *
00071  * Fields telling the service required: 
00072  *               a) transaction class (is transaction confirmed or not) 
00073  *               b) user acknowledgement flag (do we wait for response primit-
00074  *                  ive of WTP user (for instance, WSP) or not)
00075  *
00076  * Machine identification: address four-tuple and transaction identifier
00077  * 
00078  * Field required for tid verification: 
00079  *               a) packed wsp invoke indication, which is required by the 
00080  *                  protocol
00081  *
00082  * Fields required for reliable transmission: 
00083  *               a) pointer to the timer of this machine in the timers list
00084  *               b) counters for acknowledgement waiting periods and retrans- 
00085  *                  missions 
00086  *               c) flag telling are we resending the result or not
00087  *               d) similar flag for acknowledgements
00088  *               e) packed result message, for greater effectivity
00089  */
00090 
00091 #if !defined(MACHINE) 
00092     #error "Macro MACHINE is missing."
00093 #elif !defined(INTEGER) 
00094     #error "Macro INTEGER is missing."
00095 #elif !defined(ENUM) 
00096     #error "Macro ENUM is missing."
00097 #elif !defined(TIMER) 
00098     #error "Macro TIMER is missing."
00099 #elif !defined(EVENT) 
00100     #error "Macro EVENT is missing."
00101 #elif !defined(LIST)
00102     #error "Macro LIST is missing."
00103 #elif !defined(SARDATA)
00104     #error "Macro SARDATA is missing."
00105 #elif !defined(ADDRTUPLE)
00106     #error "Macro ADDRTUPLE is missing."
00107 #endif
00108 
00109 MACHINE(ENUM(state)
00110         INTEGER(tid)              /* transaction identifier */
00111         ADDRTUPLE(addr_tuple)
00112         INTEGER(tcl)              /* transaction class */
00113         INTEGER(aec)              /* counter telling how many timer periods 
00114                                       we have waited for acknowledgement */
00115         INTEGER(rcr)              /* retransmission counter */
00116         INTEGER(u_ack)            /* user acknowledgement flag (are user 
00117                                       acknowledgement required) */ 
00118         INTEGER(rid)              /* retransmission flag, telling are we 
00119                                       resending the result */ 
00120         EVENT(result)               /* packed result message - for resending */
00121         INTEGER(ack_pdu_sent)     /* are we resending the acknowledgement */
00122         TIMER(timer)              /* pointer to the timer of this machine timer
00123                                       in the global timers list */
00124         EVENT(invoke_indication) /* packed wsp invoke indication - for tid
00125                                          verification */
00126         EVENT(sar_invoke)     /* initial invoke for SAR, accumulate user_data */
00127         LIST(sar_info)
00128         SARDATA(sar)              /* ! NULL if were we asked for SAR */
00129     )
00130 
00131 #undef MACHINE
00132 #undef INTEGER
00133 #undef ENUM
00134 #undef TIMER
00135 #undef EVENT
00136 #undef LIST
00137 #undef SARDATA
00138 #undef ADDRTUPLE
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.