DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - metrics - download
Index: T p

⟦1c9347ff0⟧ TextFile

    Length: 2669 (0xa6d)
    Types: TextFile
    Names: »psaprelease2.c«

Derivation

└─⟦2d1937cfd⟧ Bits:30007241 EUUGD22: P.P 5.0
    └─⟦35176feda⟧ »EurOpenD22/isode/isode-6.tar.Z« 
        └─⟦de7628f85⟧ 
            └─⟦this⟧ »isode-6.0/psap2-lpp/psaprelease2.c« 

TextFile

/* psaprelease2.c - PPM: respond to release */

#ifndef	lint
static char *rcsid = "$Header: /f/osi/psap2-lpp/RCS/psaprelease2.c,v 7.0 89/11/23 22:15:57 mrose Rel $";
#endif

/* 
 * $Header: /f/osi/psap2-lpp/RCS/psaprelease2.c,v 7.0 89/11/23 22:15:57 mrose Rel $
 *
 * Contributed by The Wollongong Group, Inc.
 *
 *
 * $Log:	psaprelease2.c,v $
 * Revision 7.0  89/11/23  22:15:57  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>
#define	LPP
#include "PS-types.h"
#include "ppkt.h"
#include "tailor.h"

/* \f

   P-RELEASE.RESPONSE */

int	PRelResponse (sd, status, data, ndata, pi)
int	sd;
int	status;
PE     *data;
int	ndata;
struct PSAPindication *pi;
{
    SBV	    smask;
    int	    result;
    register struct psapblk *pb;

    if (status != SC_ACCEPT)
	return psaplose (pi, PC_PARAMETER, NULLCP,
			 "must accept release request");
    if (data == NULL || ndata <= 0 || data[0] == NULLPE || ndata > NPDATA_PS)
	return psaplose (pi, PC_PARAMETER, NULLCP, "bad release user data");
    if (data[0] -> pe_context != PCI_ACSE)
	return psaplose (pi, PC_PARAMETER, NULLCP,
			 "wrong context for release user data");
    missingP (pi);

    smask = sigioblock ();

    psapFsig (pb, sd);

    result = PRelResponseAux (pb, data[0], pi);

    freepblk (pb);

    (void) sigiomask (smask);

    return result;
}

/* \f

 */

static int  PRelResponseAux (pb, data, pi)
register struct psapblk *pb;
PE	data;
struct PSAPindication *pi;
{
    int	    result;
    PE	    pe;
    PS	    ps;
    register struct type_PS_ReleaseResponse__PDU *pdu;

    if ((pdu = (struct type_PS_ReleaseResponse__PDU *) malloc (sizeof *pdu))
	    == NULL)
	return psaplose (pi, PC_CONGEST, NULLCP, "out of memory");
    pdu -> reference = pb -> pb_reliability == LOW_QUALITY ? pb -> pb_reference
							   : NULLRF;
    pdu -> user__data = data;

    pe = NULLPE;
    result = encode_PS_ReleaseResponse__PDU (&pe, 1, 0, NULLCP, pdu);

    pdu -> reference = NULL;
    pdu -> user__data = NULLPE;
    free_PS_ReleaseResponse__PDU (pdu);

    if (result != NOTOK) {
	PLOG (psap2_log, print_PS_PDUs, pe, "ReleaseResponse-PDU", 0);

	if ((result = pe2ps (ps = pb -> pb_stream, pe)) == NOTOK)
	    (void) pslose (pi, ps -> ps_errno);
	else
	    result = OK;
    }
    else
	(void) psaplose (pi, PC_CONGEST, NULLCP, "error encoding PDU: %s",
			 PY_pepy);

    if (pe)
	pe_free (pe);

    return result;
}