|
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 s
Length: 3678 (0xe5e) Types: TextFile Names: »ssapresync2.c«
└─⟦3d0c2be1b⟧ Bits:30001254 ISODE-5.0 Tape └─⟦eba4602b1⟧ »./isode-5.0.tar.Z« └─⟦d3ac74d73⟧ └─⟦this⟧ »isode-5.0/ssap/ssapresync2.c«
/* ssapresync2.c - SPM: respond to resyncs */ #ifndef lint static char *rcsid = "$Header: /f/osi/ssap/RCS/ssapresync2.c,v 6.0 89/03/18 23:44:03 mrose Rel $"; #endif /* * $Header: /f/osi/ssap/RCS/ssapresync2.c,v 6.0 89/03/18 23:44:03 mrose Rel $ * * * $Log: ssapresync2.c,v $ * Revision 6.0 89/03/18 23:44:03 mrose * Release 5.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 "spkt.h" /* \f S-RESYNCHRONIZE.RESPONSE */ int SReSyncResponse (sd, ssn, settings, data, cc, si) int sd; int settings; long ssn; char *data; int cc; struct SSAPindication *si; { SBV smask; int result; register struct ssapblk *sb; missingP (si); smask = sigioblock (); ssapRsig (sb, sd); toomuchP (sb, data, cc, SN_SIZE, "resync"); result = SReSyncResponseAux (sb, ssn, settings, data, cc, si); (void) sigiomask (smask); return result; } /* \f */ static int SReSyncResponseAux (sb, ssn, settings, data, cc, si) register struct ssapblk *sb; long ssn; int settings; char *data; int cc; register struct SSAPindication *si; { int result; if (!(sb -> sb_requirements & SR_RESYNC)) return ssaplose (si, SC_OPERATION, NULLCP, "resynchronize service unavailable"); if (!(sb -> sb_flags & SB_RA)) return ssaplose (si, SC_OPERATION, NULLCP, "no resync in progress"); switch (sb -> sb_rs) { case SYNC_RESTART: ssn = sb -> sb_rsn; break; case SYNC_ABANDON: ssn = sb -> sb_V_A; break; case SYNC_SET: break; } #define dotoken(requires,shift,bit,type) \ { \ if (sb -> sb_requirements & requires) \ switch (sb -> sb_rsettings & (ST_MASK << shift)) { \ dotoken1 (requires,shift,bit,type); \ \ dotoken2 (requires,shift,bit,type); \ } \ } #define dotoken1(requires,shift,bit,type) \ case ST_CALL_VALUE << shift: \ switch (settings & (ST_MASK << shift)) { \ case ST_INIT_VALUE << shift: \ settings &= ~(ST_MASK << shift); \ settings |= ST_INIT_VALUE << shift; \ break; \ \ case ST_RESP_VALUE << shift: \ settings &= ~(ST_MASK << shift); \ settings |= ST_RESP_VALUE << shift; \ break; \ \ default: \ return ssaplose (si, SC_PARAMETER, NULLCP, \ "improper choice of %s token setting", type); \ } \ break; #define dotoken2(requires,shift,bit,type) \ default: \ if ((sb -> sb_rsettings & (ST_MASK << shift)) \ != (settings & (ST_MASK << shift))) \ return ssaplose (si, SC_OPERATION, NULLCP, \ "setting of %s token is not your choice"); \ break; dotokens (); #undef dotoken #undef dotoken1 #undef dotoken2 if ((result = SWriteRequestAux (sb, SPDU_RA, data, cc, 0, ssn, settings, NULLSD, NULLSD, NULLSR, si)) == NOTOK) freesblk (sb); else { sb -> sb_flags &= ~SB_RA; sb -> sb_V_A = sb -> sb_V_M = ssn; if (sb -> sb_rs != SYNC_RESTART) sb -> sb_V_R = 0; #define dotoken(requires,shift,bit,type) \ { \ if (sb -> sb_requirements & requires) \ switch (settings & (ST_MASK << shift)) { \ case ST_INIT_VALUE << shift: \ if (sb -> sb_flags & SB_INIT) \ sb -> sb_owned |= bit; \ else \ sb -> sb_owned &= ~bit; \ break; \ \ case ST_RESP_VALUE << shift: \ if (!(sb -> sb_flags & SB_INIT)) \ sb -> sb_owned |= bit; \ else \ sb -> sb_owned &= ~bit; \ break; \ } \ } dotokens (); #undef dotoken } return result; }