Add the DragonFly cvs id and perform general cleanups on cvs/rcs/sccs ids. Most
[dragonfly.git] / sys / net / i4b / layer2 / i4b_l2fsm.h
1 /*
2  * Copyright (c) 1997, 2000 Hellmuth Michaelis. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
14  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
17  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
19  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
20  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
21  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
22  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
23  * SUCH DAMAGE.
24  *
25  *---------------------------------------------------------------------------
26  *
27  *      i4b_l2fsm.h - layer 2 FSM
28  *      -------------------------
29  *
30  *      $Id: i4b_l2fsm.h,v 1.6 2000/03/18 09:33:48 hm Exp $ 
31  *
32  * $FreeBSD: src/sys/i4b/layer2/i4b_l2fsm.h,v 1.6.2.1 2001/08/10 14:08:41 obrien Exp $
33  * $DragonFly: src/sys/net/i4b/layer2/i4b_l2fsm.h,v 1.2 2003/06/17 04:28:40 dillon Exp $
34  *
35  *      last edit-date: [Sat Mar 18 10:28:37 2000]
36  *
37  *---------------------------------------------------------------------------*/
38
39 #ifndef _I4B_L2FSM_H_
40 #define _I4B_L2FSM_H_
41
42 enum Q921_states {
43         ST_TEI_UNAS,    /* TEI unassigned */
44         ST_ASG_AW_TEI,  /* assign awaiting TEI */
45         ST_EST_AW_TEI,  /* establish awaiting TEI */
46         ST_TEI_ASGD,    /* TEI assigned */
47
48         ST_AW_EST,      /* awaiting establishment */
49         ST_AW_REL,      /* awaiting release */
50         ST_MULTIFR,     /* multiple frame established */
51         ST_TIMREC,      /* timer recovery */
52
53         ST_SUBSET,      /* SUBroutine SETs new state */
54         ST_ILL,         /* illegal state */
55         N_STATES        /* number of states */
56 };
57
58 enum Q921_events {
59         EV_DLESTRQ,     /* dl establish req */
60         EV_DLUDTRQ,     /* dl unit data req */
61         EV_MDASGRQ,     /* mdl assign req */
62         EV_MDERRRS,     /* mdl error response */
63         EV_PSDEACT,     /* persistent deactivation */
64         EV_MDREMRQ,     /* mdl remove req */
65         EV_RXSABME,     /* rx'd SABME */
66         EV_RXDISC,      /* rx'd DISC */
67         EV_RXUA,        /* rx'd UA */
68         EV_RXDM,        /* rx'd DM */
69         EV_T200EXP,     /* T200 expired */
70         EV_DLDATRQ,     /* dl data req */
71         EV_DLRELRQ,     /* dl release req */
72         EV_T203EXP,     /* T203 expired */
73         EV_OWNBUSY,     /* set own rx busy */
74         EV_OWNRDY,      /* clear own rx busy */
75         EV_RXRR,        /* rx'd RR */
76         EV_RXREJ,       /* rx'd REJ */
77         EV_RXRNR,       /* rx'd RNR */
78         EV_RXFRMR,      /* rx'd FRMR */
79
80         EV_ILL,         /* Illegal */
81         N_EVENTS
82 };
83         
84 #endif /* _I4B_L2FSM_H_ */
85