-- *********************************************************************************************** -- TN-VLAN-MGMT-MIB.mib: Transition Networks, Inc. Enterprise MIB for VLAN management -- -- Copyright (c) 2014 by Transition Networks, Inc. -- All rights reserved. -- -- *********************************************************************************************** -- TN-VLAN-MGMT-MIB DEFINITIONS ::= BEGIN IMPORTS MODULE-IDENTITY, OBJECT-TYPE, NOTIFICATION-TYPE, IpAddress, enterprises FROM SNMPv2-SMI RowStatus, MacAddress, TEXTUAL-CONVENTION, DisplayString, TimeStamp, TruthValue FROM SNMPv2-TC entPhysicalIndex FROM ENTITY-MIB InterfaceIndexOrZero, InterfaceIndex, ifIndex FROM IF-MIB VlanIndex, PortList FROM Q-BRIDGE-MIB EightOTwoOui FROM DOT3-OAM-MIB SnmpAdminString FROM SNMP-FRAMEWORK-MIB tnProducts FROM TRANSITION-SMI; tnVlanQoSMgmtMIB MODULE-IDENTITY LAST-UPDATED "201405010000Z" ORGANIZATION "Transition Networks, Inc." CONTACT-INFO " Transition Networks Technical Support 10900 Red Circle Drive Minnetonka, MN 55343 USA Tel: +1-800-526-9267 E-mail: techsupport@transition.com" DESCRIPTION "The mib module for managing VLAN and QoS in TN platform products." REVISION "200901080000Z" DESCRIPTION "Initial Revision of this module" REVISION "201102250000Z" DESCRIPTION "Add tnVLANDbFlush and tnFIDDbFlush" REVISION "201205180000Z" DESCRIPTION "Add tnSysVlanExtMgmtPortType, tnSysVLANExtCustomSTag, tnIfVLANTagMgmt2PortType, tnIfVLANTagMgmt2TxTagType and tnIfVLANTagMgmt2ConfigConflicts" REVISION "201212210000Z" DESCRIPTION "Add Vlan Control List tnVclMgmt subtree" REVISION "201405010000Z" DESCRIPTION "Added Port VLAN Configuration Mode, Allowed VLANs, Forbidden VLANs" REVISION "201506170000Z" DESCRIPTION "Added Allowed Access VLANs tnVlanConfigGlobalsMainAccessVlans0To1K tnVlanConfigGlobalsMainAccessVlans1KTo2K tnVlanConfigGlobalsMainAccessVlans2KTo3K tnVlanConfigGlobalsMainAccessVlans3KTo4K" ::= { tnProducts 4 } -- -- Textual Conventions -- TnVlanServiceTranslationType ::= TEXTUAL-CONVENTION STATUS current DESCRIPTION "T" SYNTAX INTEGER { noTranslation(1), untaggedUntagged(2), untaggedSingleTagged(3), singleTaggedSingleTagged(4), singleTaggedTranslation(5), singleTaggedDoubleTagged(6), doubleTaggedDoubleTagged(7), doubleTaggedTranslation(8), addProviderTag(9) } TNVlanListQuarter ::= TEXTUAL-CONVENTION DISPLAY-HINT "128x" STATUS current DESCRIPTION "A list representing 1024 VLAN IDs. The type should be interpreted as a sequence of bits, each bit representing one VLAN ID. If a bit is set (1) the represented VLAN is included in the VLAN list. If a bit is not set (0) the represented VLAN is not included in the VLAN list. The least significant bit of each byte represents a smaller VLAN ID than a more significant bit of a byte. If for example the VLAN list represents VLAN IDs from 0 to 1023, bit 0 of the first byte represents VLAN ID 0, bit 1 of the first byte represents VLAN ID 1, and so on. The most significant bit of the 128th byte therefore represents VLAN ID 1023. An implementation that needs to represent all 4K VLANs will divide the VLAN list into four equally sized objects. VLAN ID 0 is included in the first object even though it is not used." SYNTAX OCTET STRING (SIZE (128)) -- -- Section 1 : -- tnVlanQoSMgmtNotifications OBJECT IDENTIFIER ::= { tnVlanQoSMgmtMIB 0 } tnVlanQoSMgmtObjects OBJECT IDENTIFIER ::= { tnVlanQoSMgmtMIB 1 } tnVlanMQoSgmtConformance OBJECT IDENTIFIER ::= { tnVlanQoSMgmtMIB 2 } -- -- TN Vlan management information -- tnSysVlanMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 1 } tnDevSysPriorityMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 2 } tnInterfaceQoSMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 3 } tnInterfaceVlanMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 4 } tnVlanServiceMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 5 } tnVlanDbMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 6 } tnFIDDbMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 7 } tnVclMgmt OBJECT IDENTIFIER ::= { tnVlanQoSMgmtObjects 8 } -- -- Management VLAN -- tnSysManagmentVLANTable OBJECT-TYPE SYNTAX SEQUENCE OF TnSysManagmentVLANEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "Management VLAN configuration table." ::= { tnSysVlanMgmt 1 } tnSysManagmentVLANEntry OBJECT-TYPE SYNTAX TnSysManagmentVLANEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "Each entry represents the management VLAN entry on a device." INDEX { entPhysicalIndex } ::= { tnSysManagmentVLANTable 1 } TnSysManagmentVLANEntry ::= SEQUENCE { tnSysMgmtVLANStatus INTEGER, tnSysMgmtVLANId INTEGER, tnSysMgmtMemberPorts BITS } tnSysMgmtVLANStatus OBJECT-TYPE SYNTAX INTEGER { enabled(1), disabled(2) } MAX-ACCESS read-write STATUS current DESCRIPTION "The device if management VLAN capable, can enable the secure channel for all its management traffic by setting this variable to enabled(1)." ::= { tnSysManagmentVLANEntry 1 } tnSysMgmtVLANId OBJECT-TYPE SYNTAX INTEGER (1..4094) MAX-ACCESS read-write STATUS current DESCRIPTION "The VLAN id, that this device will use for its management traffic. All Management frames to this device when 'tnSysManagmentVLANStatus' is set to 'enabled(1)' must be tagged with this VLAN id and all management frames from this device will be tagged with this VLAN id." ::= { tnSysManagmentVLANEntry 2 } tnSysMgmtMemberPorts OBJECT-TYPE SYNTAX BITS { none(0) } -- value added by Jing MAX-ACCESS read-write STATUS current DESCRIPTION "The ports on this device which are members of this Management VLAN. This is for security, some ports can be made not a member, which blocks all management access from this port. Each bit in this variable represents the logical port number local to the device." ::= { tnSysManagmentVLANEntry 3 } -- -- TN Switch management information -- tnSysVLANExtTable OBJECT-TYPE SYNTAX SEQUENCE OF TnSysVLANExtEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "System VLAN external configuration table." ::= { tnSysVlanMgmt 2 } tnSysVLANExtEntry OBJECT-TYPE SYNTAX TnSysVLANExtEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "Each entry represents the VLAN config on a device." INDEX { entPhysicalIndex } ::= { tnSysVLANExtTable 1 } TnSysVLANExtEntry ::= SEQUENCE { tnSysVlanExtMgmtPortType INTEGER, tnSysVLANExtCustomSTag OCTET STRING, tnVlanConfigGlobalsMainAccessVlans0To1K TNVlanListQuarter, tnVlanConfigGlobalsMainAccessVlans1KTo2K TNVlanListQuarter, tnVlanConfigGlobalsMainAccessVlans2KTo3K TNVlanListQuarter, tnVlanConfigGlobalsMainAccessVlans3KTo4K TNVlanListQuarter } tnSysVlanExtMgmtPortType OBJECT-TYPE SYNTAX INTEGER{ unaware(1), cPort(2), sPort(3), sCustomPort(4) } MAX-ACCESS read-write STATUS current DESCRIPTION "This mib variable is applicable for products that have a out of band management port. This determines the Port type for all management traffic.It can be one of the following types: Unaware, C-port, S-port, or S-custom-port where: - Unaware: The management traffic is untagged or not management vlan. - C-port: The management vlan is a C-Vlan and TPID 0x8100 is used for out of band management traffic. - S-port: The management vlan is a S-Vlan and TPID 0x88a8 is used for out of band management traffic. - S-custom-port: The management vlan is a S-Vlan, which use a custom TPID defined in tnSysVLANExtCustomSTag. " ::= { tnSysVLANExtEntry 1 } tnSysVLANExtCustomSTag OBJECT-TYPE SYNTAX OCTET STRING(SIZE(2)) MAX-ACCESS read-write STATUS current DESCRIPTION "This field specifies the Ether type used for Custom S-ports. This is a global setting and is applicable for all Custom S-ports. This field is used when TPID other than 0x8100 and 0x88a8 is needed for S-Tags." ::= { tnSysVLANExtEntry 2 } tnVlanConfigGlobalsMainAccessVlans0To1K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "First quarter of bit-array indicating the enabled access VLANs." ::= { tnSysVLANExtEntry 3 } tnVlanConfigGlobalsMainAccessVlans1KTo2K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Second quarter of bit-array indicating the enabled access VLANs." ::= { tnSysVLANExtEntry 4 } tnVlanConfigGlobalsMainAccessVlans2KTo3K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Third quarter of bit-array indicating the enabled access VLANs." ::= { tnSysVLANExtEntry 5 } tnVlanConfigGlobalsMainAccessVlans3KTo4K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Last quarter of bit-array indicating the enabled access VLANs." ::= { tnSysVLANExtEntry 6 } -- IP Priority mapping Table tnSwIPPrioTable OBJECT-TYPE SYNTAX SEQUENCE OF TnSwIPPrioEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "IP Traffic class table." ::= { tnDevSysPriorityMgmt 1 } tnSwIPPrioEntry OBJECT-TYPE SYNTAX TnSwIPPrioEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "Each entry represents the remapped value for each traffic class." INDEX { tnSwIPPrioIndex } ::= { tnSwIPPrioTable 1 } TnSwIPPrioEntry ::= SEQUENCE { tnSwIPPrioIndex INTEGER, tnSwIPPrioTC INTEGER, tnSwIPPrioRemap INTEGER } tnSwIPPrioIndex OBJECT-TYPE SYNTAX INTEGER (1..11111) -- range added by Jing MAX-ACCESS read-only STATUS current DESCRIPTION "The IP traffic class remap table index. The indexing is for a bridge entity" ::= { tnSwIPPrioEntry 1 } tnSwIPPrioTC OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-only STATUS current DESCRIPTION "The IP traffic class value." ::= { tnSwIPPrioEntry 2 } tnSwIPPrioRemap OBJECT-TYPE SYNTAX INTEGER { pri0(1), pri1(2), pri2(3), pri3(4) } MAX-ACCESS read-write STATUS current DESCRIPTION "The frames with IP traffic class set, will be remapped to the listed priority queues." ::= { tnSwIPPrioEntry 3 } -- IEEE Priority mapping Table tnSwIEEEPrioTable OBJECT-TYPE SYNTAX SEQUENCE OF TnSwIEEEPrioEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "IEEE priority remapping table." ::= { tnDevSysPriorityMgmt 2 } tnSwIEEEPrioEntry OBJECT-TYPE SYNTAX TnSwIEEEPrioEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "Each entry represents the remapped value for each priority class." INDEX { tnSwIEEEPriority } ::= { tnSwIEEEPrioTable 1 } TnSwIEEEPrioEntry ::= SEQUENCE { tnSwIEEEPriority INTEGER, tnSwIEEEPriorityRemap INTEGER } tnSwIEEEPriority OBJECT-TYPE SYNTAX INTEGER (0..7) MAX-ACCESS read-only STATUS current DESCRIPTION "The IEEE tag priority bits in the frame." ::= { tnSwIEEEPrioEntry 1 } tnSwIEEEPriorityRemap OBJECT-TYPE SYNTAX INTEGER { pri0(1), pri1(2), pri2(3), pri3(4) } MAX-ACCESS read-write STATUS current DESCRIPTION "The frames with IEEE priority bits set, will be mapped to the listed priority queues." ::= { tnSwIEEEPrioEntry 2 } -- -- ION Interface Priority Management -- tnIfPriorityTable OBJECT-TYPE SYNTAX SEQUENCE OF TnIfPriorityEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table has entries for interfaces which are capable of Priority management." ::= { tnInterfaceQoSMgmt 1 } tnIfPriorityEntry OBJECT-TYPE SYNTAX TnIfPriorityEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table represents Priority configuration." INDEX { ifIndex } ::= { tnIfPriorityTable 1 } TnIfPriorityEntry ::= SEQUENCE { tnIfDefaultPriority INTEGER, tnIfUseIEEEPriority TruthValue, tnIfUseIPPriority TruthValue, tnIfUseIPOrIEEEPriority INTEGER, tnIfSrcMACPriorityRemap TruthValue, tnIfDstMACPriorityRemap TruthValue, tnIfVIDPriorityRemap TruthValue } tnIfDefaultPriority OBJECT-TYPE SYNTAX INTEGER (0..7) MAX-ACCESS read-write STATUS current DESCRIPTION "The default priority for frames ingressing this port, if it doesnt have any IEEE 802.3ac tag or any IP TOS/Diffserv traffic class fields." ::= { tnIfPriorityEntry 1 } tnIfUseIEEEPriority OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "If the frame is IEEE tagged, and this mib variable is set to 'true', the 802.1p bits are used as the frames priority." ::= { tnIfPriorityEntry 2 } tnIfUseIPPriority OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "If the frame has IP TOS/Diffserv traffic class fields, and this mib variable is set to 'true'. The traffic class fields will be used as the frame's priority." ::= { tnIfPriorityEntry 3 } tnIfUseIPOrIEEEPriority OBJECT-TYPE SYNTAX INTEGER { useIEEE(1), useIP(2) } MAX-ACCESS read-write STATUS current DESCRIPTION "If the frame has IP TOS/Diffserv traffic class fields, and IEEE 802.3ac tagged, then this mib variable decides which one is to be considered as the frame's priority." ::= { tnIfPriorityEntry 4 } tnIfSrcMACPriorityRemap OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "When set to true(1), a frame's Source MAC address decides the priority of the frame. The new priority value is assigned based on the priority assigned to that MAC address in the MAC forwarding database." ::= { tnIfPriorityEntry 5 } tnIfDstMACPriorityRemap OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "When set to true(1), a frame's Destination MAC address decides the priority of the frame. The new priority value is assigned based on the priority assigned to that MAC address in the MAC forwarding database." ::= { tnIfPriorityEntry 6 } tnIfVIDPriorityRemap OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "When set to true(1), a frame's VLAN id decides the priority of the frame. The new priority value is assigned based on the priority assigend to that VLAN id in the VLAN database." ::= { tnIfPriorityEntry 7 } -- -- ION Interface Priority remapping -- tnIfPriorityRemapTable OBJECT-TYPE SYNTAX SEQUENCE OF TnIfPriorityRemapEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table has entries for each interface's IEEE priority remapping." ::= { tnInterfaceQoSMgmt 2 } tnIfPriorityRemapEntry OBJECT-TYPE SYNTAX TnIfPriorityRemapEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table represents Priority remapping for an interface." INDEX { ifIndex, tnIfUserPriority } ::= { tnIfPriorityRemapTable 1 } TnIfPriorityRemapEntry ::= SEQUENCE { tnIfUserPriority INTEGER, tnIfRemappedPriority INTEGER } tnIfUserPriority OBJECT-TYPE SYNTAX INTEGER (0..7) MAX-ACCESS read-only STATUS current DESCRIPTION "The priority found in the frames ingressing this interface. Frames which are untagged take up the interface's priority." ::= { tnIfPriorityRemapEntry 1 } tnIfRemappedPriority OBJECT-TYPE SYNTAX INTEGER (0..7) MAX-ACCESS read-write STATUS current DESCRIPTION "The frame's priority is remapped to this new priority value. Frames that egress tagged will have the remapped priority." ::= { tnIfPriorityRemapEntry 2 } -- -- ION Interface VLAN Management -- tnIfVLANTable OBJECT-TYPE SYNTAX SEQUENCE OF TnIfVLANEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table has entries for interfaces which are VLAN capable." ::= { tnInterfaceVlanMgmt 1 } tnIfVLANEntry OBJECT-TYPE SYNTAX TnIfVLANEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table represents VLAN configuration on an interface." INDEX { ifIndex } ::= { tnIfVLANTable 1 } TnIfVLANEntry ::= SEQUENCE { tnIfDot1qState INTEGER, tnIfDiscardTagged TruthValue, tnIfDiscardUntagged TruthValue, tnIfDefaultVlanId INTEGER, tnIfForceDefaultVlanId TruthValue } tnIfDot1qState OBJECT-TYPE SYNTAX INTEGER { vlanEnabled(1), vlanDisabled(2) } MAX-ACCESS read-write STATUS current -- SYNTAX INTEGER { vlanDisabled(1), fallback(2), check(3), secure(4) } -- MAX-ACCESS read-write -- STATUS current -- DESCRIPTION -- "The IEEE 802.1Q status of this inteface. -- vlanDisabled - 802.1Q is disabled. -- fallback - The frame is not discarded if the Vlan Id is not in the VLAN Database. It is forwarded normally. -- check - The Vlan Id must be in the VLAN Database, the ingress port may or may not be a member. -- If the Vlan Id is not in the VLAN Database, it is discarded. -- secure - The Vlan Id must be in the VLAN Database and the ingresss port should be a member -- of the VLAN, else it is discarded. -- In all the three cases when 802.1Q is enabled, the frame is allowed to egress only port is a member of the VLAN." DESCRIPTION "The IEEE802.1Q status of this interface." ::= { tnIfVLANEntry 1 } tnIfDiscardTagged OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "This filters all tagged non-management frames ingressing this port. All untagged and priority tagged frames are processed as normal frames." ::= { tnIfVLANEntry 2 } tnIfDiscardUntagged OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "This filters all untagged and priority tagged non-management frames ingressing this port. All frames .1Q tagged frames are processed as normal frames." ::= { tnIfVLANEntry 3 } tnIfDefaultVlanId OBJECT-TYPE SYNTAX INTEGER (0..4094) MAX-ACCESS read-write STATUS current DESCRIPTION "The interface's default Vlan id. This VLAN id is given to untagged frames on ingress into the device." ::= { tnIfVLANEntry 4 } tnIfForceDefaultVlanId OBJECT-TYPE SYNTAX TruthValue MAX-ACCESS read-write STATUS current DESCRIPTION "This forces all untagged and (802.1Q)tagged frames to take up the interface's ionIfDefaultVlanId." ::= { tnIfVLANEntry 5 } -- -- Tagging options at Port Level -- tnIfVLANTagMgmtTable OBJECT-TYPE SYNTAX SEQUENCE OF TnIfVLANTagMgmtEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table has entries for interfaces which are VLAN capable." ::= { tnInterfaceVlanMgmt 2 } tnIfVLANTagMgmtEntry OBJECT-TYPE SYNTAX TnIfVLANTagMgmtEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table represents VLAN configuration on an interface." INDEX { ifIndex } ::= { tnIfVLANTagMgmtTable 1 } TnIfVLANTagMgmtEntry ::= SEQUENCE { tnIfFrameTagMode INTEGER, tnIfProviderEtherType INTEGER, tnIfNetworkModeTagging INTEGER } tnIfFrameTagMode OBJECT-TYPE SYNTAX INTEGER { network(1), provider(2), customer(3) } MAX-ACCESS read-write STATUS current DESCRIPTION "The interface's taggin mode. The interface can be set as : network(1) - This is the normal network mode. It can take untagged and 802.3ac tagged frames. In this mode, 802.1q can be enabled on the interface. Frames with an ethertype of 0x8100 is considered as tagged. provider(2) - In provider mode, frames are considered provider tagged if it matches the 'ionIfProviderEtherType'. Frames which are ingress with a provider tag, are stripped of their provider tag on egressing this interface. If the frame's ethertype doesnt match the 'ionIfProviderEtherType' it is as untagged. customer(3) - The customer mode is a normal access port which is not 802.1Q aware. " ::= { tnIfVLANTagMgmtEntry 1 } tnIfProviderEtherType OBJECT-TYPE SYNTAX INTEGER { x8100(1), x9100(2), x88a8(3) } MAX-ACCESS read-write STATUS current DESCRIPTION "This ether type is used when an interface is set to 'provider' mode. Frames are considered tagged only if the ether type matches this value." ::= { tnIfVLANTagMgmtEntry 2 } tnIfNetworkModeTagging OBJECT-TYPE SYNTAX INTEGER { unmodified(1), removeTag(2), addTag(3) } MAX-ACCESS read-write STATUS current DESCRIPTION "This is available only when 'ionIfFrameTagMode' is set to 'network(1)' mode. In unmodified(1) - Frames are unmodified, the egress the same as they ingress this interface removeTag(2) - Tagged frames are stripped of their tag, and are transmitted untagged addTag(3) - Untagged frames get tagged when they egress this interface." ::= { tnIfVLANTagMgmtEntry 3 } tnIfVLANTagMgmt2Table OBJECT-TYPE SYNTAX SEQUENCE OF TnIfVLANTagMgmt2Entry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table has entries for interfaces which are VLAN capable." ::= { tnInterfaceVlanMgmt 3 } tnIfVLANTagMgmt2Entry OBJECT-TYPE SYNTAX TnIfVLANTagMgmt2Entry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table represents VLAN configuration on an interface." INDEX { ifIndex } ::= { tnIfVLANTagMgmt2Table 1 } TnIfVLANTagMgmt2Entry ::= SEQUENCE { tnIfVLANTagMgmt2PortType INTEGER, tnIfVLANTagMgmt2TxTagType INTEGER, tnIfVLANTagMgmt2ConfigConflicts INTEGER, tnVlanConfigInterfaceMode INTEGER, tnVlanConfigInterfaceAllowVlans0KTo1K TNVlanListQuarter, tnVlanConfigInterfaceAllowVlans1KTo2K TNVlanListQuarter, tnVlanConfigInterfaceAllowVlans2KTo3K TNVlanListQuarter, tnVlanConfigInterfaceAllowVlans3KTo4K TNVlanListQuarter, tnVlanConfigInterfaceForbiddenVlans0KTo1K TNVlanListQuarter, tnVlanConfigInterfaceForbiddenVlans1KTo2K TNVlanListQuarter, tnVlanConfigInterfaceForbiddenVlans2KTo3K TNVlanListQuarter, tnVlanConfigInterfaceForbiddenVlans3KTo4K TNVlanListQuarter } tnIfVLANTagMgmt2PortType OBJECT-TYPE SYNTAX INTEGER{ unaware(1), cPort(2), sPort(3), sCustomPort(4) } MAX-ACCESS read-write STATUS current DESCRIPTION "A Port can be one of the following types: Unaware, C-port, S-port, or S-custom-port where: - Unaware: all frames are classified to the Port VLAN ID and tags are not removed (default). - C-port: Customer port; with Customer tags (C-Tags), which use TPID 0x8100. - S-port: Service port; with Service tags (S-Tags), which use TPID 0x88A8 (IEEE 802.1ad). - S-custom-port: Custom Service port; with Service tags (S-Tags), which use a custom TPID assigned in tnSysVLANExtCustomSTag. For Customer tags and Service tags, both VLAN tags (tags with non-zero VID) and Priority tags (tags with VID = 0) are processed. The tag header is either retrieved from a tag in the incoming frame or from a default port-based tag header. The port-based tag header is configured in ieee8021QBridgePvid. For double-tagged frames, there is an option to use the inner tag instead of the outer tag. In addition to the tag header, the ingress port decides the number of VLAN tags to pop at egress. If the configured number of tags to pop is greater than the actual number of tags in the frame, the number is reduced to the actual number of tags in the frame. " ::= { tnIfVLANTagMgmt2Entry 1 } tnIfVLANTagMgmt2TxTagType OBJECT-TYPE SYNTAX INTEGER { untagPvid(1), tagAll(2), untagAll(3) } MAX-ACCESS read-write STATUS current DESCRIPTION "Determines egress tagging on a port: - Untag_pvid - All frames with classified VLAN as the PVID egress as untagged frames. - Tag_all - All frames which do not have a tag with classified vlan are tagged on egress. An extra tag with ingress port PVID is added if the frames are already tagged. - Untag_all - All frames tagged with the classified vlan id are untagged on egress." ::= { tnIfVLANTagMgmt2Entry 2 } tnIfVLANTagMgmt2ConfigConflicts OBJECT-TYPE SYNTAX INTEGER { no(1), yes(2) } MAX-ACCESS read-only STATUS current DESCRIPTION "Shows the status of Conflicts whether one exists or not. When a Volatile VLAN User requests to set VLAN membership or VLAN port configuration, the following conflicts can occur: - Functional Conflicts between features. - Conflicts due to hardware limitation. - Direct conflict between user modules. " ::= { tnIfVLANTagMgmt2Entry 3 } tnVlanConfigInterfaceMode OBJECT-TYPE SYNTAX INTEGER { access(1), trunk(2), hybrid(3) } MAX-ACCESS read-write STATUS current DESCRIPTION "Determines the underlying port mode. Access ports are only members of one VLAN, the AccessVlan. Trunk ports are by default members of all VLANs, which can be limited with TrunkVlans. Hybrid ports allow for changing all port VLAN parameters. As trunk ports, hybrid ports are by default members of all VLANs, which can be limited with HybridVlans." ::= { tnIfVLANTagMgmt2Entry 4 } tnVlanConfigInterfaceAllowVlans0KTo1K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "First quarter of bit-array indicating whether the port is member of a VLAN ('1') or not ('0'). Used when Mode is hybrid." ::= { tnIfVLANTagMgmt2Entry 5 } tnVlanConfigInterfaceAllowVlans1KTo2K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Second quarter of bit-array indicating whether the port is member of a VLAN ('1') or not ('0'). Used when Mode is hybrid." ::= { tnIfVLANTagMgmt2Entry 6 } tnVlanConfigInterfaceAllowVlans2KTo3K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Third quarter of bit-array indicating whether the port is member of a VLAN ('1') or not ('0'). Used when Mode is hybrid." ::= { tnIfVLANTagMgmt2Entry 7 } tnVlanConfigInterfaceAllowVlans3KTo4K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Last quarter of bit-array indicating whether the port is member of a VLAN ('1') or not ('0'). Used when Mode is hybrid." ::= { tnIfVLANTagMgmt2Entry 8 } tnVlanConfigInterfaceForbiddenVlans0KTo1K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "First quarter of bit-array indicating whether the port can ever become a member of a VLAN ('0') or not ('1'). Used in all modes." ::= { tnIfVLANTagMgmt2Entry 9 } tnVlanConfigInterfaceForbiddenVlans1KTo2K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Second quarter of bit-array indicating whether the port can ever become a member of a VLAN ('0') or not ('1'). Used in all modes." ::= { tnIfVLANTagMgmt2Entry 10 } tnVlanConfigInterfaceForbiddenVlans2KTo3K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Third quarter of bit-array indicating whether the port can ever become a member of a VLAN ('0') or not ('1'). Used in all modes." ::= { tnIfVLANTagMgmt2Entry 11 } tnVlanConfigInterfaceForbiddenVlans3KTo4K OBJECT-TYPE SYNTAX TNVlanListQuarter MAX-ACCESS read-write STATUS current DESCRIPTION "Last quarter of bit-array indicating whether the port can ever become a member of a VLAN ('0') or not ('1'). Used in all modes." ::= { tnIfVLANTagMgmt2Entry 12 } -- -- VLAN service configuration for a 2-port ION device -- tnVlanServiceConnType OBJECT-TYPE SYNTAX INTEGER { customerProvider(1), providerCustomer(2) } MAX-ACCESS read-write STATUS current DESCRIPTION "This defines the VLAN service type. The connection specified Port 1 and Port 2 configuration. customerProvider(1) : This sets the Port 1 to be customer facing port and Port 2 to be provider facing port. providerCustomer(2) : This sets the Port 1 to be provider facing port and Port 2 to be customer facing port. " ::= { tnVlanServiceMgmt 1 } tnVlanServiceVIDForTag OBJECT-TYPE SYNTAX INTEGER (1..4094) MAX-ACCESS read-write STATUS current DESCRIPTION "This Vlan id will be used when the service translation requires an extra tag to be added." ::= { tnVlanServiceMgmt 2 } tnVlanServiceEtherTypeForTag OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-write STATUS current DESCRIPTION "This Ethertype will be used when the service translation requires an extra tag to be added. Typical values are 0x8100 for IEEE 802.1Q tags, 0x88a8 for IEEE 802.1ad S-tags or other 2 byte private ethertype." ::= { tnVlanServiceMgmt 3 } tnVlanServiceTranslation OBJECT-TYPE SYNTAX TnVlanServiceTranslationType MAX-ACCESS read-write STATUS current DESCRIPTION "This determines the service or flow type between the two terminations. The translation type as the flow passes the termination points from Customer edge to provider edge are detailed below : <----- Provider Side -----> <----- Customer Side -----> Device +------------------------------+ ----> | P | | P | ----> ----> | o | | o | ----> <---- | r | | r | <---- <---- | t | | t | <---- |(PE)| |(CE)| +------------------------------+ noTranslation(1) :- The ingress flow might contain any kind of frames, untagged or single or double tagged. The egress flow will be exactly the same, no translation is done. untaggedUntagged(2) :- The traffic should be untagged, all tagged frames will be discarded. The traffic that egress the device contain the untagged flow without any modification. untaggedSingleTagged(3) :- At the CE the traffic should be untagged. At the PE the traffic will contain a single tag with the VID specified in tnVlanServiceVIDForTag. singleTaggedSingleTagged(4) :- The traffic should be single tagged on ingress and on egress with no translation. singleTaggedTranslation(5) :- The traffic should be single tagged on ingress and on egress. The only changes from the singleTaggedSingleTagged(4), there is a translation. The Vlan Id that came on ingress is translated to a different Vlan Id on egress. singleTaggedDoubleTagged(6) :- At the CE the traffic should be single tagged. At the PE the traffic will contain an extra tag with the VID specified in tnVlanServiceVIDForTag. doubleTaggedDoubleTagged(7) :- The traffic should be double tagged on ingress and on egress with no translation. doubleTaggedTranslation(8) :- The traffic should be double tagged on ingress and on egress. The only changes from the doubleTaggedDoubleTagged(7), there is a translation. The Vlan Id in outer tag that came on CE is translated to a different Vlan Id on PE. The inner tag remains intact. addProviderTag(9) :- This option adds an extra tag on the PE interface, no matter what kind of traffic at CE. This strips the outer tag for traffic from PE interface egressing the CE interface. " ::= { tnVlanServiceMgmt 4 } -- -- VLAN database -- tnVLANDbTable OBJECT-TYPE SYNTAX SEQUENCE OF TnVLANDbEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table contains all VLAN entries for this bridge." ::= { tnVlanDbMgmt 1 } tnVLANDbEntry OBJECT-TYPE SYNTAX TnVLANDbEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table represents a VLAN and the interfaces that are members of that VLAN." INDEX { tnVlanDbVID } ::= { tnVLANDbTable 1 } TnVLANDbEntry ::= SEQUENCE { tnVlanDbVID VlanIndex, tnVlanDbFID INTEGER, tnVlanDbVIDPriOverride INTEGER, tnVlanDbVIDPriority INTEGER, tnVlanDbMemTagPort1 INTEGER, tnVlanDbMemTagPort2 INTEGER, tnVlanDbMemTagPort3 INTEGER, tnVlanDbMemTagPort4 INTEGER, tnVlanDbMemTagPort5 INTEGER, tnVlanDbMemTagPort6 INTEGER, tnVlanDbMemTagPort7 INTEGER, tnVlanDbMemTagPort8 INTEGER, tnVlanDbMemTagPort9 INTEGER, tnVlanDbMemTagPort10 INTEGER, tnVlanDbRowStatus RowStatus } tnVlanDbVID OBJECT-TYPE SYNTAX VlanIndex MAX-ACCESS read-only STATUS current DESCRIPTION "The VLAN ID of the entry." ::= { tnVLANDbEntry 1 } tnVlanDbFID OBJECT-TYPE SYNTAX INTEGER (0..255) MAX-ACCESS read-only STATUS current DESCRIPTION "The Forwarding Database number for this VLAN." ::= { tnVLANDbEntry 2 } tnVlanDbVIDPriOverride OBJECT-TYPE SYNTAX INTEGER { enable(1), disable(2) } MAX-ACCESS read-create STATUS current DESCRIPTION "Override Priority on frames assosicated with this VID." ::= { tnVLANDbEntry 3 } tnVlanDbVIDPriority OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "Priority for frames assosicated with this VID." ::= { tnVLANDbEntry 4 } tnVlanDbMemTagPort1 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 1. memEgressNoMode(1)- Port 1 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 1 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 1 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 1 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 5 } tnVlanDbMemTagPort2 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 2. memEgressNoMode(1)- Port 2 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 2 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 2 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 2 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 6 } tnVlanDbMemTagPort3 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 3. memEgressNoMode(1)- Port 3 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 3 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 3 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 3 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 7 } tnVlanDbMemTagPort4 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 4. memEgressNoMode(1)- Port 4 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 4 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 4 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 4 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 8 } tnVlanDbMemTagPort5 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 5. memEgressNoMode(1)- Port 5 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 5 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 5 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 5 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 9 } tnVlanDbMemTagPort6 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 6. memEgressNoMode(1)- Port 6 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 6 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 6 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 6 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 10 } tnVlanDbMemTagPort7 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 7. memEgressNoMode(1)- Port 7 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 7 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 7 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 7 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 11 } tnVlanDbMemTagPort8 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 8. memEgressNoMode(1)- Port 8 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 8 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 8 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 8 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 12 } tnVlanDbMemTagPort9 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 9. memEgressNoMode(1)- Port 9 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 9 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 9 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 9 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 13 } tnVlanDbMemTagPort10 OBJECT-TYPE SYNTAX INTEGER { memEgressNoMod(1), memEgressNoTag(2), memEgressTag(3), notMember(4), notApplicable(5) } MAX-ACCESS read-create STATUS current DESCRIPTION "Membership and Egress Tagging on Logical Port 10. memEgressNoMode(1)- Port 10 is a member of this VLAN and frames that egress are unmodified. memEgressNoTag(2) - Port 10 is a member of this VLAN and frames that egress are untagged. memEgressTag(3) - Port 10 is a member of this VLAN and frames that egress are tagged. notMember(4) - Port 10 is not a member of this VLAN and frames that ingress with this VID are discarded. notApplicable(5) is returned if there is no valid port." ::= { tnVLANDbEntry 14 } tnVlanDbRowStatus OBJECT-TYPE SYNTAX RowStatus MAX-ACCESS read-create STATUS current DESCRIPTION "The status of this VLAN entry in the VLAN database." ::= { tnVLANDbEntry 15 } tnVLANDbFlush OBJECT IDENTIFIER ::= { tnVlanDbMgmt 2 } tnVLANDbFlushOperation OBJECT-TYPE SYNTAX INTEGER { doNothing(1), flushAll(2) } MAX-ACCESS read-write STATUS current DESCRIPTION "Set this viarable to: flushAll(2): flush all VLAN entries except default VLAN 1. This variable can't be set if the 'tnVLANDbFlushOperationStatus' is 'inProgress(4)'. Do getting to this variable: If an operation is being processed, the operation being processed is returned. If no operation is being processed, 'doNothing(1)' is returned." ::= { tnVLANDbFlush 1 } tnVLANDbFlushOperationStatus OBJECT-TYPE SYNTAX INTEGER { unknown(1), success(2), failure(3), inProgress(4) } MAX-ACCESS read-only STATUS current DESCRIPTION "The VLAN database flush operation status. unknown(1): no flush operation has been performed. success(2)/failure(3): the last flush operation is finished, success(2) indicates the last flush operation is successful. failure(3) indicates the last flush operation fails. inProgress(4): flush operation is in progress." ::= { tnVLANDbFlush 2 } tnVLANDbFlushOperationFailureReason OBJECT-TYPE SYNTAX DisplayString (SIZE (0..63)) MAX-ACCESS read-only STATUS current DESCRIPTION "Specifies the description of the cause of 'failure(3)' state of the object 'tnVLANDbFlushOperationStatus'. This object would be a null string if value of 'tnVLANDbFlushOperationStatus' is anything other than 'failure(3)'." ::= { tnVLANDbFlush 3 } -- -- Forwarding database -- tnFIDDbTable OBJECT-TYPE SYNTAX SEQUENCE OF TnFIDDbEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "The forwarding/filtering address database for this device." ::= { tnFIDDbMgmt 1 } tnFIDDbEntry OBJECT-TYPE SYNTAX TnFIDDbEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "Information about a particular MAC address." INDEX { tnFIDDbID, tnFIDDbMacAddress } ::= { tnFIDDbTable 1 } TnFIDDbEntry ::= SEQUENCE { tnFIDDbID INTEGER, tnFIDDbMacAddress MacAddress, tnFIDDbConnPort INTEGER, tnFIDDbPriority INTEGER, tnFIDDbEntryType INTEGER, tnFIDDbEntryStatus RowStatus } tnFIDDbID OBJECT-TYPE SYNTAX INTEGER (0..255) MAX-ACCESS read-only STATUS current DESCRIPTION "The Forwarding Database Number. This identifies the database." ::= { tnFIDDbEntry 2 } tnFIDDbMacAddress OBJECT-TYPE SYNTAX MacAddress MAX-ACCESS read-only STATUS current DESCRIPTION "The unicast or multicast MAC address that the device has forwarding information." ::= { tnFIDDbEntry 3 } tnFIDDbConnPort OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "The index of the logical Port from which the device received the 'tnFIDDbMacAddress'." ::= { tnFIDDbEntry 4 } tnFIDDbPriority OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "The priority of this MAC entry." ::= { tnFIDDbEntry 5 } tnFIDDbEntryType OBJECT-TYPE SYNTAX INTEGER { static(1), staticNRL(2), staticPA(3), dynamic(4) } MAX-ACCESS read-create STATUS current DESCRIPTION "The Entry state of this unicast or multicast entry. The types represent : static(1) - A Valid entry that doesnot age. staticNRL(2) - A static entry that has no ingress rate limiting. staticPA(3) - A static entry that has priority override enabled. dynamic(4) - A valid entry with no special attributes which ages and finally removed from the database. A unicast entry can be static(1) or staticPA(3) but not staticNRL(2). For MAC address which are learned, the read-only value of dynamic(4) is returned." ::= { tnFIDDbEntry 6 } tnFIDDbEntryStatus OBJECT-TYPE SYNTAX RowStatus MAX-ACCESS read-create STATUS current DESCRIPTION "The status of this entry." ::= { tnFIDDbEntry 7 } tnFIDDbFlush OBJECT IDENTIFIER ::= { tnFIDDbMgmt 2 } tnFIDDbFlushFID OBJECT-TYPE SYNTAX INTEGER(0..4094) MAX-ACCESS read-write STATUS current DESCRIPTION "When 'tnFIDDbFlushOperation' is 'flushAllFID(3)' or 'flushAllDynamicFID(4)', the value(1..4094) of this viarable is used to specify the FID to be flushed. The value 0 of this virable means no FID is specified." ::= { tnFIDDbFlush 1 } tnFIDDbFlushOperation OBJECT-TYPE SYNTAX INTEGER { doNothing(1), flushAll(2), flushAllDynamic(3), flushAllFID(4), flushAllDynamicFID(5) } MAX-ACCESS read-write STATUS current DESCRIPTION "Set this viarable to: flushAll(2): flush all FID entries for all FIDs. flushAllDynamic(3): flush all FID dynamic entries for all FIDs. flushAllFID(4): flush all FID entries for one FID which is specified by ionFIDDbFlushFID. flushAllDynamicFID(5): flush all FID dynamic entries for one FID which is specified by ionFIDDbFlushFID. This variable can't be set if the 'ionFIDDbFlushOperationStatus' is 'inProgress(4)'. Do getting to this variable: If an operation is being processed, the operation being processed is returned. If no operation is being processed, 'doNothing(1)' is returned." ::= { tnFIDDbFlush 2 } tnFIDDbFlushOperationStatus OBJECT-TYPE SYNTAX INTEGER { unknown(1), success(2), failure(3), inProgress(4) } MAX-ACCESS read-only STATUS current DESCRIPTION "The FID database flush operation status. unknown(1): no flush operation has been performed. success(2)/failure(3): the last flush operation is finished, success(2) indicates the last flush operation is successful. failure(3) indicates the last flush operation fails. inProgress(4): flush operation is in progress." ::= { tnFIDDbFlush 3 } tnFIDDbFlushOperationFailureReason OBJECT-TYPE SYNTAX DisplayString (SIZE (0..63)) MAX-ACCESS read-only STATUS current DESCRIPTION "Specifies the description of the cause of 'failure(3)' state of the object 'ionFIDDbFlushOperationStatus'. This object would be a null string if value of 'ionFIDDbFlushOperationStatus' is anything other than 'failure(3)'." ::= { tnFIDDbFlush 4 } -- -- VLAN Control List -- tnVclMacBasedMgmt OBJECT IDENTIFIER ::= { tnVclMgmt 1 } tnVclProtoBasedMgmt OBJECT IDENTIFIER ::= { tnVclMgmt 2 } tnVclIpSubnetBasedMgmt OBJECT IDENTIFIER ::= { tnVclMgmt 3 } -- -- Mac based Vlan -- tnVclMacBasedTable OBJECT-TYPE SYNTAX SEQUENCE OF TnVclMacBasedEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table is used to control MAC based Vlan functions." ::= { tnVclMacBasedMgmt 1 } tnVclMacBasedEntry OBJECT-TYPE SYNTAX TnVclMacBasedEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in the table is used to control MAC based Vlan functions." INDEX { tnVclMacBasedMacAddr } ::= { tnVclMacBasedTable 1 } TnVclMacBasedEntry ::= SEQUENCE { tnVclMacBasedMacAddr MacAddress, tnVclMacBasedVlanId VlanIndex, tnVclMacBasedPortMember PortList, tnVclMacBasedUser INTEGER, tnVclMacBasedRowStatus RowStatus } tnVclMacBasedMacAddr OBJECT-TYPE SYNTAX MacAddress MAX-ACCESS not-accessible STATUS current DESCRIPTION "The MAC address is used for the MAC based VLAN function classification key." ::= { tnVclMacBasedEntry 1 } tnVclMacBasedVlanId OBJECT-TYPE SYNTAX VlanIndex MAX-ACCESS read-create STATUS current DESCRIPTION "The Vlan Id will be assigned to the incoming frame(if needed) which matches this specific MAC address and port member list." ::= { tnVclMacBasedEntry 2 } tnVclMacBasedPortMember OBJECT-TYPE SYNTAX PortList MAX-ACCESS read-create STATUS current DESCRIPTION "The member port list of this specific MAC based Vlan match process takes place." ::= { tnVclMacBasedEntry 3 } tnVclMacBasedUser OBJECT-TYPE SYNTAX INTEGER{ static(1), nas(2) } MAX-ACCESS read-only STATUS current DESCRIPTION "The creater of this entry. The MAC based VLAN entry is either created by user configuration(static), or by NAS dynamic creation(nas)." ::= { tnVclMacBasedEntry 4 } tnVclMacBasedRowStatus OBJECT-TYPE SYNTAX RowStatus MAX-ACCESS read-create STATUS current DESCRIPTION "The status of this entry." ::= { tnVclMacBasedEntry 5 } -- -- Protocol Based Vlan -- tnVclProtoBasedGroupMapTable OBJECT-TYPE SYNTAX SEQUENCE OF TnVclProtoBasedGroupMapEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This table is used to build a specific protocol group for VCL match process." ::= { tnVclProtoBasedMgmt 1 } tnVclProtoBasedGroupMapEntry OBJECT-TYPE SYNTAX TnVclProtoBasedGroupMapEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in this table is used to build a specific protocol group for VCL match process." -- INDEX { IMPLIED tnVclProtoBasedGroupMapName } INDEX { tnVclProtoBasedGroupMapName } ::= { tnVclProtoBasedGroupMapTable 1 } TnVclProtoBasedGroupMapEntry ::= SEQUENCE { tnVclProtoBasedGroupMapName SnmpAdminString, tnVclProtoBasedGroupMapProtocol INTEGER, tnVclProtoBasedGroupMapEtherTypeVal INTEGER, tnVclProtoBasedGroupMapSnapOui EightOTwoOui, tnVclProtoBasedGroupMapSnapPid INTEGER, tnVclProtoBasedGroupMapLlcDsap INTEGER, tnVclProtoBasedGroupMapLlcSsap INTEGER, tnVclProtoBasedGroupMapRowStatus RowStatus } tnVclProtoBasedGroupMapName OBJECT-TYPE SYNTAX SnmpAdminString MAX-ACCESS not-accessible STATUS current DESCRIPTION "The locally arbitrary, but unique identifier associated with this TnVclProtoBasedGroupMapEntry." ::= { tnVclProtoBasedGroupMapEntry 1 } tnVclProtoBasedGroupMapProtocol OBJECT-TYPE SYNTAX INTEGER{ ethernet(1), snap(2), llc(3) } MAX-ACCESS read-create STATUS current DESCRIPTION "Frame Type can have one of the following values: 1. Ethernet 2. SNAP 3. LLC" ::= { tnVclProtoBasedGroupMapEntry 2 } tnVclProtoBasedGroupMapEtherTypeVal OBJECT-TYPE SYNTAX INTEGER(1536..65535) MAX-ACCESS read-create STATUS current DESCRIPTION "Ethernet Type is valid only if the tnVclProtoBasedGroupMapProtocol is ethernet(1). Valid values for etype ranges is from 0x0600-0xffff. If tnVclProtoBasedGroupMapProtocol is not ethernet(1), this value will be 0xffff instead." ::= { tnVclProtoBasedGroupMapEntry 3 } tnVclProtoBasedGroupMapSnapOui OBJECT-TYPE SYNTAX EightOTwoOui MAX-ACCESS read-create STATUS current DESCRIPTION "SNAP OUI is valid only if the tnVclProtoBasedGroupMapProtocol is snap(2). OUI (Organizationally Unique Identifier) is value in format of xx-xx-xx where each pair (xx) in string is a hexadecimal value ranges from 0x00-0xff. If tnVclProtoBasedGroupMapProtocol is not snap(2), this value will be FF-FF-FF instead." ::= { tnVclProtoBasedGroupMapEntry 4 } tnVclProtoBasedGroupMapSnapPid OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "SNAP PID is valid only if the tnVclProtoBasedGroupMapProtocol is snap(2). If the OUI is hexadecimal 000000, the protocol ID is the Ethernet type (EtherType) field value for the protocol running on top of SNAP; if the OUI is an OUI for a particular organization, the protocol ID is a value assigned by that organization to the protocol running on top of SNAP. In other words, if value of OUI field is 00-00-00 then value of PID will be etype (0x0600-0xffff) and if value of OUI is other than 00-00-00 then valid value of PID will be any value from 0x0000 to 0xffff. If tnVclProtoBasedGroupMapProtocol is not snap(2), this value will be 0xffff instead." ::= { tnVclProtoBasedGroupMapEntry 5 } tnVclProtoBasedGroupMapLlcDsap OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "LLC DSAP is valid only if the tnVclProtoBasedGroupMapProtocol is llc(3). DSAP: 1-byte long string (0x00-0xff). If tnVclProtoBasedGroupMapProtocol is not llc(3), this value will be 0xff instead." ::= { tnVclProtoBasedGroupMapEntry 6 } tnVclProtoBasedGroupMapLlcSsap OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "LLC SSAP is valid only if the tnVclProtoBasedGroupMapProtocol is llc(3). SSAP: 1-byte long string (0x00-0xff). If tnVclProtoBasedGroupMapProtocol is not llc(3), this value will be 0xff instead." ::= { tnVclProtoBasedGroupMapEntry 7 } tnVclProtoBasedGroupMapRowStatus OBJECT-TYPE SYNTAX RowStatus MAX-ACCESS read-create STATUS current DESCRIPTION "The status of this entry." ::= { tnVclProtoBasedGroupMapEntry 8 } -- -- tnVclProtoBasedVlanMapTable OBJECT-TYPE SYNTAX SEQUENCE OF TnVclProtoBasedVlanMapEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "The table is used to associate the protocol based VLAN groups with VLAN paramaters." ::= { tnVclProtoBasedMgmt 2 } tnVclProtoBasedVlanMapEntry OBJECT-TYPE SYNTAX TnVclProtoBasedVlanMapEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in this table is used to associate the protocol based VLAN groups with VLAN paramaters." INDEX { IMPLIED tnVclProtoBasedGroupMapName, tnVclProtoBasedVlanMapVlanId } ::= { tnVclProtoBasedVlanMapTable 1 } TnVclProtoBasedVlanMapEntry ::= SEQUENCE { tnVclProtoBasedVlanMapVlanId VlanIndex, tnVclProtoBasedVlanMapPortMember PortList, tnVclProtoBasedVlanMapRowStatus RowStatus } tnVclProtoBasedVlanMapVlanId OBJECT-TYPE SYNTAX VlanIndex MAX-ACCESS read-create STATUS current DESCRIPTION "The Vlan Id will be assigned to the incoming frame(if needed) which matches this specific Protocol Group and port member list." ::= { tnVclProtoBasedVlanMapEntry 1 } tnVclProtoBasedVlanMapPortMember OBJECT-TYPE SYNTAX PortList MAX-ACCESS read-create STATUS current DESCRIPTION "The member port list of this specific Protocol based Vlan match process takes place." ::= { tnVclProtoBasedVlanMapEntry 2 } tnVclProtoBasedVlanMapRowStatus OBJECT-TYPE SYNTAX RowStatus MAX-ACCESS read-create STATUS current DESCRIPTION "The status of this entry." ::= { tnVclProtoBasedVlanMapEntry 3 } -- -- IP subnet based Vlan -- tnVclIpSubnetBasedTable OBJECT-TYPE SYNTAX SEQUENCE OF TnVclIpSubnetBasedEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "This Table is used to control IP subnet based VLAN functions." ::= { tnVclIpSubnetBasedMgmt 1 } tnVclIpSubnetBasedEntry OBJECT-TYPE SYNTAX TnVclIpSubnetBasedEntry MAX-ACCESS not-accessible STATUS current DESCRIPTION "A entry in this table is used to control IP subnet based VLAN functions." INDEX { tnVclIpSubnetBasedVceId } ::= { tnVclIpSubnetBasedTable 1 } TnVclIpSubnetBasedEntry ::= SEQUENCE { tnVclIpSubnetBasedVceId INTEGER, tnVclIpSubnetBasedIpAddr IpAddress, tnVclIpSubnetBasedMaskLen INTEGER, tnVclIpSubnetBasedVlanId VlanIndex, tnVclIpSubnetBasedPortMember PortList, tnVclIpSubnetBasedRowStatus RowStatus } tnVclIpSubnetBasedVceId OBJECT-TYPE SYNTAX INTEGER (1..11111) -- range added by Jing MAX-ACCESS not-accessible STATUS current DESCRIPTION "Indicates the index of the entry. The valid range is implement specific. If VCE ID is 0, application will auto-generate the VCE ID for that entry." ::= { tnVclIpSubnetBasedEntry 1 } tnVclIpSubnetBasedIpAddr OBJECT-TYPE SYNTAX IpAddress MAX-ACCESS read-create STATUS current DESCRIPTION "Indicates the IP address for match process." ::= { tnVclIpSubnetBasedEntry 2 } tnVclIpSubnetBasedMaskLen OBJECT-TYPE SYNTAX INTEGER MAX-ACCESS read-create STATUS current DESCRIPTION "Indicates the network mask length." ::= { tnVclIpSubnetBasedEntry 3 } tnVclIpSubnetBasedVlanId OBJECT-TYPE SYNTAX VlanIndex MAX-ACCESS read-create STATUS current DESCRIPTION "The Vlan Id will be assigned to the incoming frame(if needed) which matches this specific IP subnet and port member list." ::= { tnVclIpSubnetBasedEntry 4 } tnVclIpSubnetBasedPortMember OBJECT-TYPE SYNTAX PortList MAX-ACCESS read-create STATUS current DESCRIPTION "The member port list of this specific IP subnet based Vlan match process takes place." ::= { tnVclIpSubnetBasedEntry 5 } tnVclIpSubnetBasedRowStatus OBJECT-TYPE SYNTAX RowStatus MAX-ACCESS read-create STATUS current DESCRIPTION "The status of this entry." ::= { tnVclIpSubnetBasedEntry 6 } -- -- NOTIFICATIONS FOR THIS MIB -- tnIfSourceAddrChangeEvt NOTIFICATION-TYPE OBJECTS { tnFIDDbMacAddress, tnFIDDbConnPort } STATUS current DESCRIPTION "A tnIfSourceAddrChangeEvt event is sent when the tnIfSourceAddrLock is set to 'true', the ionIfSourceAddrLockAction is set to 'discardAndNotify' or 'all' and there is an intrusion/SA change on this port." ::= { tnVlanQoSMgmtNotifications 1 } END