1*4eaa4710SRishi Srivatsavai /************************************************************************ 2*4eaa4710SRishi Srivatsavai * RSTP library - Rapid Spanning Tree (802.1t, 802.1w) 3*4eaa4710SRishi Srivatsavai * Copyright (C) 2001-2003 Optical Access 4*4eaa4710SRishi Srivatsavai * Author: Alex Rozin 5*4eaa4710SRishi Srivatsavai * 6*4eaa4710SRishi Srivatsavai * This file is part of RSTP library. 7*4eaa4710SRishi Srivatsavai * 8*4eaa4710SRishi Srivatsavai * RSTP library is free software; you can redistribute it and/or modify it 9*4eaa4710SRishi Srivatsavai * under the terms of the GNU Lesser General Public License as published by the 10*4eaa4710SRishi Srivatsavai * Free Software Foundation; version 2.1 11*4eaa4710SRishi Srivatsavai * 12*4eaa4710SRishi Srivatsavai * RSTP library is distributed in the hope that it will be useful, but 13*4eaa4710SRishi Srivatsavai * WITHOUT ANY WARRANTY; without even the implied warranty of 14*4eaa4710SRishi Srivatsavai * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser 15*4eaa4710SRishi Srivatsavai * General Public License for more details. 16*4eaa4710SRishi Srivatsavai * 17*4eaa4710SRishi Srivatsavai * You should have received a copy of the GNU Lesser General Public License 18*4eaa4710SRishi Srivatsavai * along with RSTP library; see the file COPYING. If not, write to the Free 19*4eaa4710SRishi Srivatsavai * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 20*4eaa4710SRishi Srivatsavai * 02111-1307, USA. 21*4eaa4710SRishi Srivatsavai **********************************************************************/ 22*4eaa4710SRishi Srivatsavai 23*4eaa4710SRishi Srivatsavai /* Note: this state mashine distinkts from described in P802.1t Clause 18. */ 24*4eaa4710SRishi Srivatsavai /* I am ready to discuss it */ 25*4eaa4710SRishi Srivatsavai 26*4eaa4710SRishi Srivatsavai #include "base.h" 27*4eaa4710SRishi Srivatsavai #include "stpm.h" 28*4eaa4710SRishi Srivatsavai #include "stp_vectors.h" 29*4eaa4710SRishi Srivatsavai 30*4eaa4710SRishi Srivatsavai #define STATES { \ 31*4eaa4710SRishi Srivatsavai CHOOSE(DISABLED), \ 32*4eaa4710SRishi Srivatsavai CHOOSE(DETECTED), \ 33*4eaa4710SRishi Srivatsavai CHOOSE(DELAYED), \ 34*4eaa4710SRishi Srivatsavai CHOOSE(RESOLVED) \ 35*4eaa4710SRishi Srivatsavai } 36*4eaa4710SRishi Srivatsavai 37*4eaa4710SRishi Srivatsavai #define GET_STATE_NAME STP_edge_get_state_name 38*4eaa4710SRishi Srivatsavai #include "choose.h" 39*4eaa4710SRishi Srivatsavai 40*4eaa4710SRishi Srivatsavai #define DEFAULT_LINK_DELAY 3 41*4eaa4710SRishi Srivatsavai 42*4eaa4710SRishi Srivatsavai void 43*4eaa4710SRishi Srivatsavai STP_edge_enter_state (STATE_MACH_T *s) 44*4eaa4710SRishi Srivatsavai { 45*4eaa4710SRishi Srivatsavai register PORT_T *port = s->owner.port; 46*4eaa4710SRishi Srivatsavai 47*4eaa4710SRishi Srivatsavai switch (s->State) { 48*4eaa4710SRishi Srivatsavai case BEGIN: 49*4eaa4710SRishi Srivatsavai break; 50*4eaa4710SRishi Srivatsavai case DISABLED: 51*4eaa4710SRishi Srivatsavai port->operEdge = port->adminEdge; 52*4eaa4710SRishi Srivatsavai port->wasInitBpdu = False; 53*4eaa4710SRishi Srivatsavai port->lnkWhile = 0; 54*4eaa4710SRishi Srivatsavai port->portEnabled = False; 55*4eaa4710SRishi Srivatsavai break; 56*4eaa4710SRishi Srivatsavai case DETECTED: 57*4eaa4710SRishi Srivatsavai port->portEnabled = True; 58*4eaa4710SRishi Srivatsavai port->lnkWhile = port->LinkDelay; 59*4eaa4710SRishi Srivatsavai port->operEdge = False; 60*4eaa4710SRishi Srivatsavai break; 61*4eaa4710SRishi Srivatsavai case DELAYED: 62*4eaa4710SRishi Srivatsavai break; 63*4eaa4710SRishi Srivatsavai case RESOLVED: 64*4eaa4710SRishi Srivatsavai if (! port->wasInitBpdu) { 65*4eaa4710SRishi Srivatsavai port->operEdge = port->adminEdge; 66*4eaa4710SRishi Srivatsavai } 67*4eaa4710SRishi Srivatsavai break; 68*4eaa4710SRishi Srivatsavai } 69*4eaa4710SRishi Srivatsavai } 70*4eaa4710SRishi Srivatsavai 71*4eaa4710SRishi Srivatsavai Bool 72*4eaa4710SRishi Srivatsavai STP_edge_check_conditions (STATE_MACH_T *s) 73*4eaa4710SRishi Srivatsavai { 74*4eaa4710SRishi Srivatsavai register PORT_T *port = s->owner.port; 75*4eaa4710SRishi Srivatsavai 76*4eaa4710SRishi Srivatsavai /* If we're disabled, then stay that way. */ 77*4eaa4710SRishi Srivatsavai if (!port->adminEnable) { 78*4eaa4710SRishi Srivatsavai if (s->State == DISABLED) 79*4eaa4710SRishi Srivatsavai return False; 80*4eaa4710SRishi Srivatsavai else 81*4eaa4710SRishi Srivatsavai return STP_hop_2_state (s, DISABLED); 82*4eaa4710SRishi Srivatsavai } 83*4eaa4710SRishi Srivatsavai 84*4eaa4710SRishi Srivatsavai switch (s->State) { 85*4eaa4710SRishi Srivatsavai case BEGIN: 86*4eaa4710SRishi Srivatsavai return STP_hop_2_state (s, DISABLED); 87*4eaa4710SRishi Srivatsavai case DISABLED: 88*4eaa4710SRishi Srivatsavai if (port->adminEnable) { 89*4eaa4710SRishi Srivatsavai return STP_hop_2_state (s, DETECTED); 90*4eaa4710SRishi Srivatsavai } 91*4eaa4710SRishi Srivatsavai break; 92*4eaa4710SRishi Srivatsavai case DETECTED: 93*4eaa4710SRishi Srivatsavai return STP_hop_2_state (s, DELAYED); 94*4eaa4710SRishi Srivatsavai case DELAYED: 95*4eaa4710SRishi Srivatsavai if (port->wasInitBpdu) { 96*4eaa4710SRishi Srivatsavai #ifdef STP_DBG 97*4eaa4710SRishi Srivatsavai if (s->debug) 98*4eaa4710SRishi Srivatsavai stp_trace ("port %s 'edge' resolved by BPDU", port->port_name); 99*4eaa4710SRishi Srivatsavai #endif 100*4eaa4710SRishi Srivatsavai return STP_hop_2_state (s, RESOLVED); 101*4eaa4710SRishi Srivatsavai } 102*4eaa4710SRishi Srivatsavai 103*4eaa4710SRishi Srivatsavai if (! port->lnkWhile) { 104*4eaa4710SRishi Srivatsavai #ifdef STP_DBG 105*4eaa4710SRishi Srivatsavai if (s->debug) 106*4eaa4710SRishi Srivatsavai stp_trace ("port %s 'edge' resolved by timer", port->port_name); 107*4eaa4710SRishi Srivatsavai #endif 108*4eaa4710SRishi Srivatsavai return STP_hop_2_state (s, RESOLVED); 109*4eaa4710SRishi Srivatsavai } 110*4eaa4710SRishi Srivatsavai break; 111*4eaa4710SRishi Srivatsavai case RESOLVED: 112*4eaa4710SRishi Srivatsavai break; 113*4eaa4710SRishi Srivatsavai } 114*4eaa4710SRishi Srivatsavai return False; 115*4eaa4710SRishi Srivatsavai } 116