|
|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - metrics - downloadIndex: T c
Length: 4598 (0x11f6)
Types: TextFile
Names: »conn_release.c«
└─⟦2d1937cfd⟧ Bits:30007241 EUUGD22: P.P 5.0
└─⟦35176feda⟧ »EurOpenD22/isode/isode-6.tar.Z«
└─⟦de7628f85⟧
└─⟦this⟧ »isode-6.0/quipu/conn_release.c«
/* conn_release.c - normal association release */
#ifndef lint
static char *rcsid = "$Header: /f/osi/quipu/RCS/conn_release.c,v 7.0 89/11/23 22:16:48 mrose Rel $";
#endif
/*
* $Header: /f/osi/quipu/RCS/conn_release.c,v 7.0 89/11/23 22:16:48 mrose Rel $
*
*
* $Log: conn_release.c,v $
* Revision 7.0 89/11/23 22:16:48 mrose
* Release 6.0
*
*/
/*
* NOTICE
*
* Acquisition, use, and distribution of this module and related
* materials are subject to the restrictions of a license agreement.
* Consult the Preface in the User's Manual for the full terms of
* this agreement.
*
*/
/* LINTLIBRARY */
#include "acsap.h"
#include "rosap.h"
#include "quipu/util.h"
#include "quipu/connection.h"
extern LLog * log_dsap;
Conn conn_alloc();
void conn_free();
void acs_log ();
extern time_t time();
conn_release(conn)
struct connection * conn;
{
struct AcSAPrelease acr_s;
struct AcSAPrelease *acr = &(acr_s);
struct AcSAPindication aci_s;
struct AcSAPindication *aci = &(aci_s);
struct AcSAPabort *aca = &(aci->aci_abort);
DLOG(log_dsap, LLOG_TRACE, ("conn_release"));
DLOG(log_dsap, LLOG_NOTICE, ("RY-UNBIND: <%d, normal, nullpe>", conn->cn_ad));
watch_dog ("RyUnBind");
switch (RyUnBindAux (conn->cn_ad, ACF_NORMAL, NULLPE, acr, aci, OK)) {
case NOTOK:
watch_dog_reset();
do_ds_unbind(conn);
DLOG(log_dsap, LLOG_TRACE, ("conn_release: acr_affirmative = %d", acr->acr_affirmative));
acs_log(aca, "A-RELEASE.REQUEST");
break;
case OK:
watch_dog_reset();
DLOG(log_dsap, LLOG_TRACE, ("conn_release: acr_affirmative = %d", acr->acr_affirmative));
if (!acr->acr_affirmative)
{
if ((conn->cn_last_release == conn->cn_last_used)
&& (conn->cn_initiator == INITIATED_BY_THIS)) {
LLOG (log_dsap,LLOG_EXCEPTIONS,("conn_release rejected again without activity - Aborting %d",conn->cn_ad));
do_ds_unbind(conn);
conn_rel_abort (conn);
} else {
LLOG (log_dsap,LLOG_EXCEPTIONS,("conn_release rejected - continuing with association %d",conn->cn_ad));
conn->cn_last_release = conn->cn_last_used = time((time_t *) 0);
return NOTOK;
}
}
else
{
do_ds_unbind(conn);
DLOG(log_dsap, LLOG_TRACE, ("conn_release: Conn finished!"));
}
break;
case DONE:
watch_dog_reset();
DLOG (log_dsap,LLOG_NOTICE, ("Waiting for release"));
conn->cn_state = CN_CLOSING;
conn->cn_last_release = conn->cn_last_used = time((time_t *) 0);
return NOTOK;
default:
watch_dog_reset();
LLOG (log_dsap, LLOG_EXCEPTIONS, ("Unexpected return from RyUnBindAux"));
return NOTOK;
}
DLOG(log_dsap, LLOG_DEBUG, ("conn_release calling conn_extract"));
conn_extract(conn);
return OK;
}
conn_release_retry(conn)
struct connection * conn;
{
struct AcSAPrelease acr_s;
struct AcSAPrelease *acr = &(acr_s);
struct AcSAPindication aci_s;
struct AcSAPindication *aci = &(aci_s);
struct AcSAPabort *aca = &(aci->aci_abort);
DLOG(log_dsap, LLOG_NOTICE, ("conn_release retry (%d)",conn->cn_ad));
watch_dog ("RyUnBindRetry");
switch (RyUnBindRetry (conn->cn_ad, acr, aci)) {
case NOTOK:
watch_dog_reset();
do_ds_unbind(conn);
DLOG(log_dsap, LLOG_TRACE, ("conn_release: acr_affirmative = %d", acr->acr_affirmative));
acs_log(aca, "A-RELEASE.REQUEST");
break;
case OK:
watch_dog_reset();
DLOG(log_dsap, LLOG_TRACE, ("conn_release: acr_affirmative = %d", acr->acr_affirmative));
if (!acr->acr_affirmative)
{
if ((conn->cn_last_release == conn->cn_last_used)
&& (conn->cn_initiator == INITIATED_BY_THIS)) {
LLOG (log_dsap,LLOG_EXCEPTIONS,("conn_release rejected again without activity - Aborting %d",conn->cn_ad));
do_ds_unbind(conn);
conn_rel_abort (conn);
} else {
LLOG (log_dsap,LLOG_EXCEPTIONS,("conn_release rejected - continuing with association %d",conn->cn_ad));
conn->cn_last_release = conn->cn_last_used = time((time_t *) 0);
return NOTOK;
}
}
else
{
do_ds_unbind(conn);
DLOG(log_dsap, LLOG_TRACE, ("conn_release: Conn finished!"));
}
break;
case DONE:
watch_dog_reset();
DLOG (log_dsap,LLOG_TRACE, ("Still Waiting for release"));
conn->cn_last_release = conn->cn_last_used = time((time_t *) 0);
return NOTOK;
default:
watch_dog_reset();
LLOG (log_dsap, LLOG_EXCEPTIONS, ("Unexpected return from RyUnBindAux"));
return NOTOK;
}
DLOG(log_dsap, LLOG_DEBUG, ("conn_release calling conn_extract"));
conn_extract(conn);
return OK;
}