.\" Automatically generated by Pod::Man 4.07 (Pod::Simple 3.32) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .if !\nF .nr F 0 .if \nF>0 \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} .\} .\" ======================================================================== .\" .IX Title "Info::Layer3::C3550 3pm" .TH Info::Layer3::C3550 3pm "2016-12-21" "perl v5.24.1" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" SNMP::Info::Layer3::C3550 \- SNMP Interface to Cisco Catalyst 3550 Layer 2/3 Switches running IOS .SH "AUTHOR" .IX Header "AUTHOR" Max Baker .SH "SYNOPSIS" .IX Header "SYNOPSIS" .Vb 10 \& # Let SNMP::Info determine the correct subclass for you. \& my $c3550 = new SNMP::Info( \& AutoSpecify => 1, \& Debug => 1, \& # These arguments are passed directly to SNMP::Session \& DestHost => \*(Aqmyswitch\*(Aq, \& Community => \*(Aqpublic\*(Aq, \& Version => 2 \& ) \& or die "Can\*(Aqt connect to DestHost.\en"; \& \& my $class = $c3550\->class(); \& print "SNMP::Info determined this device to fall under subclass : $class\en"; .Ve .SH "DESCRIPTION" .IX Header "DESCRIPTION" Abstraction subclass for Cisco Catalyst 3550 Layer 2/3 Switches. .PP These devices run \s-1IOS\s0 but have some of the same characteristics as the Catalyst WS-C family (5xxx,6xxx). For example, forwarding tables are held in VLANs, and extended interface information is gleaned from \fICISCO-SWITCH-MIB\fR. .PP For speed or debugging purposes you can call the subclass directly, but not after determining a more specific class using the method above. .PP .Vb 1 \& my $c3550 = new SNMP::Info::Layer3::C3550(...); .Ve .SS "Inherited Classes" .IX Subsection "Inherited Classes" .IP "SNMP::Info::CiscoStack" 4 .IX Item "SNMP::Info::CiscoStack" .PD 0 .IP "SNMP::Info::Layer3::CiscoSwitch" 4 .IX Item "SNMP::Info::Layer3::CiscoSwitch" .PD .SS "Required MIBs" .IX Subsection "Required MIBs" .IP "Inherited Classes' MIBs" 4 .IX Item "Inherited Classes' MIBs" See \*(L"Required MIBs\*(R" in SNMP::Info::CiscoStack for its own \s-1MIB\s0 requirements. .Sp See \*(L"Required MIBs\*(R" in SNMP::Info::Layer3::CiscoSwitch for its own \s-1MIB\s0 requirements. .SH "GLOBALS" .IX Header "GLOBALS" These are methods that return scalar value from \s-1SNMP\s0 .ie n .IP "$c3550\->\fIvendor()\fR" 4 .el .IP "\f(CW$c3550\fR\->\fIvendor()\fR" 4 .IX Item "$c3550->vendor()" Returns 'cisco' .ie n .IP "$c3550\->\fImodel()\fR" 4 .el .IP "\f(CW$c3550\fR\->\fImodel()\fR" 4 .IX Item "$c3550->model()" Will take the translated model number and try to format it better. .Sp .Vb 2 \& 355048 \-> 3550\-48 \& 355012G \-> 3550\-12G .Ve .ie n .IP "$c3550\->\fIports()\fR" 4 .el .IP "\f(CW$c3550\fR\->\fIports()\fR" 4 .IX Item "$c3550->ports()" Tries to cull the number of ports from the model number. .SS "Globals imported from SNMP::Info::CiscoStack" .IX Subsection "Globals imported from SNMP::Info::CiscoStack" See documentation in \*(L"\s-1GLOBALS\*(R"\s0 in SNMP::Info::CiscoStack for details. .SS "Globals imported from SNMP::Info::Layer3::CiscoSwitch" .IX Subsection "Globals imported from SNMP::Info::Layer3::CiscoSwitch" See documentation in \*(L"\s-1GLOBALS\*(R"\s0 in SNMP::Info::Layer3::CiscoSwitch for details. .SH "TABLE METHODS" .IX Header "TABLE METHODS" These are methods that return tables of information in the form of a reference to a hash. .SS "Overrides" .IX Subsection "Overrides" .ie n .IP "$c3550\->\fIi_duplex()\fR" 4 .el .IP "\f(CW$c3550\fR\->\fIi_duplex()\fR" 4 .IX Item "$c3550->i_duplex()" Returns reference to hash of iid to current link duplex setting. .Sp Software version 12.1(22)EA1a or greater returns duplex based upon the result of \f(CW$c3550\fR\->\fIel_duplex()\fR. Otherwise it uses the result of the call to \fICiscoStack::i_duplex()\fR. .Sp See SNMP::Info::Etherlike for \fIel_duplex()\fR method and SNMP::Info::CiscoStack for its \fIi_duplex()\fR method. .ie n .IP "$c3550\->\fIi_duplex_admin()\fR" 4 .el .IP "\f(CW$c3550\fR\->\fIi_duplex_admin()\fR" 4 .IX Item "$c3550->i_duplex_admin()" Returns reference to hash of iid to administrative duplex setting. .Sp Software version 12.1(22)EA1a or greater returns duplex based upon the result of \f(CW$c3550\fR\->\fIp_duplex()\fR. Otherwise it uses the result of the call to \fICiscoStack::i_duplex()\fR. .Sp See SNMP::Info::CiscoStack for its \fIi_duplex()\fR and \fIp_duplex()\fR methods. .ie n .IP "$c3550\->set_i_duplex_admin(duplex, ifIndex)" 4 .el .IP "\f(CW$c3550\fR\->set_i_duplex_admin(duplex, ifIndex)" 4 .IX Item "$c3550->set_i_duplex_admin(duplex, ifIndex)" Sets port duplex, must be supplied with duplex and port \f(CW\*(C`ifIndex\*(C'\fR. .Sp Speed choices are 'auto', 'half', 'full'. .Sp Crosses \f(CW$c3550\fR\->\fIp_port()\fR with \f(CW$c3550\fR\->\fIp_duplex()\fR to utilize port \f(CW\*(C`ifIndex\*(C'\fR. .Sp .Vb 4 \& Example: \& my %if_map = reverse %{$c3550\->interfaces()}; \& $c3550\->set_i_duplex_admin(\*(Aqauto\*(Aq, $if_map{\*(AqFastEthernet0/1\*(Aq}) \& or die "Couldn\*(Aqt change port duplex. ",$c3550\->error(1); .Ve .SS "Table Methods imported from SNMP::Info::CiscoStack" .IX Subsection "Table Methods imported from SNMP::Info::CiscoStack" See documentation in \*(L"\s-1TABLE METHODS\*(R"\s0 in SNMP::Info::CiscoStack for details. .SS "Table Methods imported from SNMP::Info::Layer3::CiscoSwitch" .IX Subsection "Table Methods imported from SNMP::Info::Layer3::CiscoSwitch" See documentation in \*(L"\s-1TABLE METHODS\*(R"\s0 in SNMP::Info::Layer3::CiscoSwitch for details.