|
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 p
Length: 3971 (0xf83) Types: TextFile Names: »psaprelease1.c«
└─⟦2d1937cfd⟧ Bits:30007241 EUUGD22: P.P 5.0 └─⟦35176feda⟧ »EurOpenD22/isode/isode-6.tar.Z« └─⟦de7628f85⟧ └─⟦this⟧ »isode-6.0/psap2/psaprelease1.c«
/* psaprelease1.c - PPM: initiate release */ #ifndef lint static char *rcsid = "$Header: /f/osi/psap2/RCS/psaprelease1.c,v 7.0 89/11/23 22:14:26 mrose Rel $"; #endif /* * $Header: /f/osi/psap2/RCS/psaprelease1.c,v 7.0 89/11/23 22:14:26 mrose Rel $ * * * $Log: psaprelease1.c,v $ * Revision 7.0 89/11/23 22:14:26 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 <stdio.h> #include <signal.h> #include "ppkt.h" /* \f P-RELEASE.REQUEST */ int PRelRequest (sd, data, ndata, secs, pr, pi) int sd; PE *data; int ndata; int secs; struct PSAPrelease *pr; struct PSAPindication *pi; { SBV smask; int result; register struct psapblk *pb; toomuchP (data, ndata, NPDATA, "release"); missingP (pr); missingP (pi); smask = sigioblock (); psapPsig (pb, sd); switch (result = info2ssdu (pb, pi, data, ndata, &pb -> pb_realbase, &pb -> pb_retry, &pb -> pb_len, "P-RELEASE user-data", PPDU_NONE)) { case OK: default: result = PRelRetryRequestAux (pb, secs, pr, pi); goto out; case NOTOK: freepblk (pb), pb = NULLPB; break; case DONE: result = NOTOK; break; } if (pb) { if (pb -> pb_realbase) free (pb -> pb_realbase); else if (pb -> pb_retry) free (pb -> pb_retry); pb -> pb_realbase = pb -> pb_retry = NULL; } out: ; (void) sigiomask (smask); return result; } /* \f P-RELEASE-RETRY.REQUEST (pseudo) */ int PRelRetryRequest (sd, secs, pr, pi) int sd; int secs; struct PSAPrelease *pr; struct PSAPindication *pi; { SBV smask; int result; register struct psapblk *pb; missingP (pr); missingP (pi); smask = sigioblock (); if ((pb = findpblk (sd)) == NULL) result = psaplose (pi, PC_PARAMETER, NULLCP, "invalid session descriptor"); else if (!(pb -> pb_flags & PB_RELEASE)) result = psaplose (pi, PC_OPERATION, "release not in progress"); else result = PRelRetryRequestAux (pb, secs, pr, pi); (void) sigiomask (smask); return result; } /* \f */ static int PRelRetryRequestAux (pb, secs, pr, pi) struct psapblk *pb; int secs; struct PSAPrelease *pr; struct PSAPindication *pi; { int result; char *id = pb -> pb_flags & PB_RELEASE ? "SRelRetryRequest" : "SRelRequest"; struct SSAPrelease srs; register struct SSAPrelease *sr = &srs; struct SSAPindication sis; register struct SSAPabort *sa = &sis.si_abort; bzero ((char *) sr, sizeof *sr); if ((result = (pb -> pb_flags & PB_RELEASE) ? SRelRetryRequest (pb -> pb_fd, secs, sr, &sis) : SRelRequest (pb -> pb_fd, pb -> pb_retry, pb -> pb_len, secs, sr, &sis)) == NOTOK) { if (sa -> sa_reason == SC_TIMER) { pb -> pb_flags |= PB_RELEASE; return ss2pslose (NULLPB, pi, id, sa); } if (sa -> sa_peer) { (void) ss2psabort (pb, sa, pi); goto out1; } if (SC_FATAL (sa -> sa_reason)) { (void) ss2pslose (pb, pi, id, sa); goto out2; } else { (void) ss2pslose (NULLPB, pi, id, sa); goto out1; } } bzero ((char *) pr, sizeof *pr); if ((result = ssdu2info (pb, pi, sr -> sr_data, sr -> sr_cc, pr -> pr_info, &pr -> pr_ninfo, "P-RELEASE user-data", PPDU_NONE)) == NOTOK) goto out2; if (pr -> pr_affirmative = sr -> sr_affirmative) { pb -> pb_fd = NOTOK; result = OK; } else result = DONE; out2: ; if (result == DONE) result = OK; else freepblk (pb), pb = NULLPB; out1: ; SRFREE (sr); if (pb) { if (pb -> pb_realbase) free (pb -> pb_realbase); else if (pb -> pb_retry) free (pb -> pb_retry); pb -> pb_realbase = pb -> pb_retry = NULL; } return result; }