288 lines
11 KiB
C
288 lines
11 KiB
C
/*
|
|
*
|
|
* ===================================
|
|
* HARP | Host ATM Research Platform
|
|
* ===================================
|
|
*
|
|
*
|
|
* This Host ATM Research Platform ("HARP") file (the "Software") is
|
|
* made available by Network Computing Services, Inc. ("NetworkCS")
|
|
* "AS IS". NetworkCS does not provide maintenance, improvements or
|
|
* support of any kind.
|
|
*
|
|
* NETWORKCS MAKES NO WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED,
|
|
* INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
* AND FITNESS FOR A PARTICULAR PURPOSE, AS TO ANY ELEMENT OF THE
|
|
* SOFTWARE OR ANY SUPPORT PROVIDED IN CONNECTION WITH THIS SOFTWARE.
|
|
* In no event shall NetworkCS be responsible for any damages, including
|
|
* but not limited to consequential damages, arising from or relating to
|
|
* any use of the Software or related support.
|
|
*
|
|
* Copyright 1994-1998 Network Computing Services, Inc.
|
|
*
|
|
* Copies of this Software may be made, however, the above copyright
|
|
* notice must be reproduced on all copies.
|
|
*
|
|
* @(#) $FreeBSD$
|
|
*
|
|
*/
|
|
|
|
/*
|
|
* ATM Forum UNI Support
|
|
* ---------------------
|
|
*
|
|
* SSCOP protocol control blocks
|
|
*
|
|
*/
|
|
|
|
#ifndef _UNI_SSCOP_VAR_H
|
|
#define _UNI_SSCOP_VAR_H
|
|
|
|
/*
|
|
* Structure containing information for each SSCOP connection.
|
|
*/
|
|
struct sscop {
|
|
struct sscop *so_next; /* Next connection in chain */
|
|
u_char so_state; /* Connection state (see below) */
|
|
u_short so_flags; /* Connection flags (see below) */
|
|
enum sscop_vers so_vers; /* SSCOP version */
|
|
|
|
/* Transmitter variables */
|
|
sscop_seq so_send; /* VT(S) - next SD to send */
|
|
sscop_seq so_sendmax; /* VT(MS) - max SD to send + 1 */
|
|
sscop_seq so_ack; /* VT(A) - next expected ack */
|
|
sscop_seq so_pollsend; /* VT(PS) - last POLL sent */
|
|
sscop_seq so_pollack; /* VT(PA) - next expected STAT */
|
|
short so_polldata; /* VT(PD) - SD's sent between POLLs */
|
|
short so_connctl; /* VT(CC) - un-ack'd BGN,END,ER,RS */
|
|
u_char so_sendconn; /* VT(SQ) - last BGN,ER,RS sent */
|
|
|
|
/* Receiver variables */
|
|
sscop_seq so_rcvnext; /* VR(R) - next SD to receive */
|
|
sscop_seq so_rcvhigh; /* VR(H) - next highest SD to receive */
|
|
sscop_seq so_rcvmax; /* VR(MR) - max SD to receive + 1 */
|
|
u_char so_rcvconn; /* VR(SQ) - last BGN,ER,RS received */
|
|
|
|
/* PDU queues */
|
|
KBuffer *so_xmit_hd; /* SD transmission queue head */
|
|
KBuffer *so_xmit_tl; /* SD transmission queue tail */
|
|
struct pdu_hdr *so_rexmit_hd; /* SD retransmission queue head */
|
|
struct pdu_hdr *so_rexmit_tl; /* SD retransmission queue head */
|
|
struct pdu_hdr *so_pack_hd; /* SD pending ack queue head */
|
|
struct pdu_hdr *so_pack_tl; /* SD pending ack queue tail */
|
|
struct pdu_hdr *so_recv_hd; /* SD receive queue head */
|
|
struct pdu_hdr *so_recv_tl; /* SD receive queue tail */
|
|
|
|
/* Connection parameters */
|
|
struct sscop_parms so_parm; /* Connection parameters */
|
|
|
|
/* Timers */
|
|
u_short so_timer[SSCOP_T_NUM]; /* Connection timers */
|
|
|
|
/* Stack variables */
|
|
Atm_connvc *so_connvc; /* Connection vcc for this stack */
|
|
void *so_toku; /* Stack upper layer's token */
|
|
void *so_tokl; /* Stack lower layer's token */
|
|
void (*so_upper) /* Stack upper layer's interface */
|
|
(int, void *, intptr_t, intptr_t);
|
|
void (*so_lower) /* Stack lower layer's interface */
|
|
(int, void *, intptr_t, intptr_t);
|
|
u_short so_headout; /* Output buffer headroom */
|
|
};
|
|
|
|
/*
|
|
* Connection States
|
|
*
|
|
* Notes:
|
|
* # - state valid only for Q.SAAL1
|
|
* ## - state valid only for Q.2110
|
|
*/
|
|
#define SOS_INST 0 /* Instantiated, waiting for INIT */
|
|
#define SOS_IDLE 1 /* Idle connection */
|
|
#define SOS_OUTCONN 2 /* Outgoing connection pending */
|
|
#define SOS_INCONN 3 /* Incoming connection pending */
|
|
#define SOS_OUTDISC 4 /* Outgoing disconnection pending */
|
|
#define SOS_OUTRESYN 5 /* Outgoing resynchronization pending */
|
|
#define SOS_INRESYN 6 /* Incoming resynchronization pending */
|
|
#define SOS_CONRESYN 7 /* Concurrent resynch pending (#) */
|
|
#define SOS_OUTRECOV 7 /* Outgoing recovery pending (##) */
|
|
#define SOS_RECOVRSP 8 /* Recovery response pending (##) */
|
|
#define SOS_INRECOV 9 /* Incoming recovery pending (##) */
|
|
#define SOS_READY 10 /* Data transfer ready */
|
|
#define SOS_TERM 11 /* Waiting for TERM */
|
|
|
|
#define SOS_MAXSTATE 11 /* Maximum state value */
|
|
#define SOS_NUMSTATES (SOS_MAXSTATE+1)/* Number of states */
|
|
|
|
/*
|
|
* Connection Flags
|
|
*/
|
|
#define SOF_NOCLRBUF 0x0001 /* Clear buffers = no */
|
|
#define SOF_REESTAB 0x0002 /* SSCOP initiated reestablishment */
|
|
#define SOF_XMITSRVC 0x0004 /* Transmit queues need servicing */
|
|
#define SOF_KEEPALIVE 0x0008 /* Polling in transient phase */
|
|
#define SOF_ENDSSCOP 0x0010 /* Last END PDU, SOURCE=SSCOP */
|
|
#define SOF_NOCREDIT 0x0020 /* Transmit window closed */
|
|
|
|
|
|
/*
|
|
* SSCOP statistics
|
|
*/
|
|
struct sscop_stat {
|
|
u_long sos_connects; /* Connection instances */
|
|
u_long sos_aborts; /* Connection aborts */
|
|
u_long sos_maa_error[MAA_ERROR_COUNT]; /* Management errors */
|
|
};
|
|
|
|
#ifdef _KERNEL
|
|
|
|
#include <vm/uma.h>
|
|
|
|
/*
|
|
* Global function declarations
|
|
*/
|
|
/* sscop.c */
|
|
int sscop_start(void);
|
|
int sscop_stop(void);
|
|
void sscop_maa_error(struct sscop *, int);
|
|
void sscop_abort(struct sscop *, char *);
|
|
|
|
/* sscop_lower.c */
|
|
void sscop_lower(int, void *, intptr_t, intptr_t);
|
|
void sscop_aa_noop_0(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_aa_noop_1(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_init_inst(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_term_all(struct sscop *, intptr_t, intptr_t);
|
|
|
|
/* sscop_pdu.c */
|
|
int sscop_send_bgn(struct sscop *, int);
|
|
int sscop_send_bgak(struct sscop *);
|
|
int sscop_send_bgrej(struct sscop *);
|
|
int sscop_send_end(struct sscop *, int);
|
|
int sscop_send_endak(struct sscop *);
|
|
int sscop_send_rs(struct sscop *);
|
|
int sscop_send_rsak(struct sscop *);
|
|
int sscop_send_er(struct sscop *);
|
|
int sscop_send_erak(struct sscop *);
|
|
int sscop_send_poll(struct sscop *);
|
|
int sscop_send_stat(struct sscop *, sscop_seq);
|
|
int sscop_send_ustat(struct sscop *, sscop_seq);
|
|
int sscop_send_ud(struct sscop *, KBuffer *);
|
|
void sscop_pdu_print(const struct sscop *,
|
|
const KBuffer *, const char *);
|
|
|
|
/* sscop_sigaa.c */
|
|
void sscop_estreq_idle(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_estrsp_inconn(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_relreq_outconn(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_relreq_inconn(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_relreq_ready(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_datreq_ready(struct sscop *, intptr_t, intptr_t);
|
|
void sscop_udtreq_all(struct sscop *, intptr_t, intptr_t);
|
|
|
|
/* sscop_sigcpcs.c */
|
|
void sscop_noop(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgn_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgn_outdisc(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgn_outresyn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgn_inresyn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgak_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgak_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgak_outconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgrej_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgrej_outconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgrej_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgrej_outresyn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_bgrej_ready(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_end_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_end_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_end_outdisc(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_endak_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_endak_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_endak_outdisc(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_endak_ready(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_rs_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_rs_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_rsak_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_rsak_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_rsak_outresyn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_sd_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_sd_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_sd_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_poll_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_poll_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_poll_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_stat_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_stat_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_stat_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_stat_ready(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_ustat_error(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_ustat_idle(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_ustat_inconn(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_ustat_ready(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_ud_all(struct sscop *, KBuffer *, caddr_t);
|
|
void sscop_md_all(struct sscop *, KBuffer *, caddr_t);
|
|
|
|
/* sscop_subr.c */
|
|
KBuffer * sscop_stat_getelem(KBuffer *, sscop_seq *);
|
|
struct pdu_hdr *sscop_pack_locate(struct sscop *, sscop_seq);
|
|
void sscop_pack_free(struct sscop *, sscop_seq);
|
|
void sscop_rexmit_insert(struct sscop *, struct pdu_hdr *);
|
|
void sscop_rexmit_unlink(struct sscop *, struct pdu_hdr *);
|
|
void sscop_xmit_drain(struct sscop *);
|
|
int sscop_recv_insert(struct sscop *, struct pdu_hdr *);
|
|
void sscop_rcvr_drain(struct sscop *);
|
|
void sscop_service_xmit(struct sscop *);
|
|
int sscop_is_rexmit(struct sscop *, u_char);
|
|
void sscop_set_poll(struct sscop *);
|
|
|
|
/* sscop_timer.c */
|
|
void sscop_timeout(struct atm_time *);
|
|
|
|
/* sscop_upper.c */
|
|
void sscop_upper(int, void *, intptr_t, intptr_t);
|
|
|
|
/* q2110_sigaa.c */
|
|
|
|
/* q2110_sigcpcs.c */
|
|
|
|
/* q2110_subr.c */
|
|
void q2110_clear_xmit(struct sscop *);
|
|
void q2110_init_state(struct sscop *);
|
|
void q2110_prep_retrieve(struct sscop *);
|
|
void q2110_prep_recovery(struct sscop *);
|
|
void q2110_deliver_data(struct sscop *);
|
|
void q2110_error_recovery(struct sscop *);
|
|
|
|
/* qsaal1_sigaa.c */
|
|
|
|
/* qsaal1_sigcpcs.c */
|
|
|
|
/* qsaal1_subr.c */
|
|
void qsaal1_reestablish(struct sscop *);
|
|
void qsaal1_reset_xmit(struct sscop *);
|
|
void qsaal1_reset_rcvr(struct sscop *);
|
|
void qsaal1_clear_connection(struct sscop *);
|
|
|
|
|
|
/*
|
|
* External variables
|
|
*/
|
|
extern uma_zone_t sscop_zone;
|
|
extern int sscop_vccnt;
|
|
extern struct sscop *sscop_head;
|
|
extern struct sscop_stat sscop_stat;
|
|
extern struct atm_time sscop_timer;
|
|
extern void (*(*sscop_qsaal_aatab[]))
|
|
(struct sscop *, intptr_t, intptr_t);
|
|
extern void (*(*sscop_q2110_aatab[]))
|
|
(struct sscop *, intptr_t, intptr_t);
|
|
extern void (*(*sscop_qsaal_pdutab[]))
|
|
(struct sscop *, KBuffer *, caddr_t);
|
|
extern void (*(*sscop_q2110_pdutab[]))
|
|
(struct sscop *, KBuffer *, caddr_t);
|
|
|
|
#endif /* _KERNEL */
|
|
|
|
#endif /* _UNI_SSCOP_VAR_H */
|