/* * Copyright (c) 2000 Apple Computer, Inc. All rights reserved. * * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ * * This file contains Original Code and/or Modifications of Original Code * as defined in and that are subject to the Apple Public Source License * Version 2.0 (the 'License'). You may not use this file except in * compliance with the License. The rights granted to you under the License * may not be used to create, or enable the creation or redistribution of, * unlawful or unlicensed copies of an Apple operating system, or to * circumvent, violate, or enable the circumvention or violation of, any * terms of an Apple operating system software license agreement. * * Please obtain a copy of the License at * http://www.opensource.apple.com/apsl/ and read it before using this file. * * The Original Code and all software distributed under the License are * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. * Please see the License for the specific language governing rights and * limitations under the License. * * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ */ /* * Copyright (c) 1996 Apple Computer, Inc. * * Created April 8, 1996 by Tuyen Nguyen * Modified, March 17, 1997 by Tuyen Nguyen for MacOSX. * * File: tickle.c */ #ifdef AURP_SUPPORT #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /* */ void AURPsndTickle(state) aurp_state_t *state; { int msize; gbuf_t *m; aurp_hdr_t *hdrp; atalk_lock(); if (state->rcv_state == AURPSTATE_Unconnected) { atalk_unlock(); return; } /* stop trying if the retry count exceeds the maximum retry value */ if (++state->tickle_retry > AURP_MaxTickleRetry) { dPrintf(D_M_AURP, D_L_WARNING, ("AURPsndTickle: no response, %d\n", state->rem_node)); /* * the tunnel peer seems to have disappeared, update state info */ state->snd_state = AURPSTATE_Unconnected; state->rcv_state = AURPSTATE_Unconnected; state->tickle_retry = 0; AURPcleanup(state); /* purge all routes associated with the tunnel peer */ AURPpurgeri(state->rem_node); atalk_unlock(); return; } if (state->tickle_retry > 1) { msize = sizeof(aurp_hdr_t); if ((m = (gbuf_t *)gbuf_alloc(msize, PRI_MED)) != 0) { gbuf_wset(m,msize); /* construct the tickle packet */ hdrp = (aurp_hdr_t *)gbuf_rptr(m); hdrp->connection_id = state->rcv_connection_id; hdrp->sequence_number = 0; hdrp->command_code = AURPCMD_Tickle; hdrp->flags = 0; /* send the packet */ AURPsend(m, AUD_AURP, state->rem_node); } } /* start the retry timer */ timeout(AURPsndTickle, state, AURP_TickleRetryInterval*HZ); atalk_unlock(); } /* */ void AURPrcvTickle(state, m) aurp_state_t *state; gbuf_t *m; { aurp_hdr_t *hdrp = (aurp_hdr_t *)gbuf_rptr(m); /* make sure we're in a valid state to accept it */ if (state->snd_state == AURPSTATE_Unconnected) { dPrintf(D_M_AURP, D_L_WARNING, ("AURPrcvTickle: unexpected request\n")); gbuf_freem(m); return; } /* construct the tickle ack packet */ gbuf_wset(m,sizeof(aurp_hdr_t)); hdrp->command_code = AURPCMD_TickleAck; hdrp->flags = 0; /* send the packet */ AURPsend(m, AUD_AURP, state->rem_node); } /* */ void AURPrcvTickleAck(state, m) aurp_state_t *state; gbuf_t *m; { aurp_hdr_t *hdrp = (aurp_hdr_t *)gbuf_rptr(m); /* make sure we're in a valid state to accept it */ if (state->rcv_state == AURPSTATE_Unconnected) { dPrintf(D_M_AURP, D_L_WARNING, ("AURPrcvTickleAck: unexpected response\n")); gbuf_freem(m); return; } /* check for the correct connection id */ if (hdrp->connection_id != state->rcv_connection_id) { dPrintf(D_M_AURP, D_L_WARNING, ("AURPrcvTickleAck: invalid connection id, r=%d, m=%d\n", hdrp->connection_id, state->rcv_connection_id)); gbuf_freem(m); return; } gbuf_freem(m); /* update state info */ state->tickle_retry = 0; } #endif /* AURP_SUPPORT */