vdptool (8) - Linux Manuals
vdptool: manage the VSI associations and status of lldpad
NAME
vdptool - manage the VSI associations and status of lldpadSYNOPSIS
vdptool <command> [options] [argument]DESCRIPTION
vdptool is used to query and configure the VSI associations in lldpad. Only the ratified stardard version of the VDP protocol (also refered to as vdp22) is supported. It connects to the client interface of lldpad to perform these operations. vdptool will operate in interactive mode if it is executed without a command. In interactive mode, vdptool will also function as an event listener to print out events as they are received asynchronously from lldpad(still to be done). It will use libreadline for interactive input when available (still to be done).OPTIONS
- -i [ifname]
- specifies the network interface to which the command applies. Most vdptool commands require specifying a network interface.
- -V [tlvid]
-
specifies the VDP tlv identifier to be set or queried.
The tlvid is an integer value used to identify specific VDP TLVs. The tlvid value is the type value for types not equal to 127 (the organizationally specific type). For organizationally specific TLVs, the tlvid is the value represented by the 3 byte OUI and 1 byte subtype - where the subtype is the lowest order byte of the tlvid.
The tlvid can be entered as a numerical value (e.g. 10 or 0xa), or for supported TLVs, as a keyword (such as assoc, deassoc, preassoc, preassoc-rr, etc). Review the vdptool help output to see the list of supported TLV keywords.Use option -c to specify the parameters and its values to be set or queried.
- -n
- "neighbor" option for commands which can use it (e.g. get-tlv). Use this flag to retrieve the last VDP22 data returned from the bridge. (not yet supported).
- -c <argument list>
- Specifies additional parameters for TLV queries and associations commands. The argument list varies, depending on the command option (-T) or (-t). To establish a VSI association use the command option (-T) and specify additional information as arguments in the form of key=value. See the VSI Parameter subsection and Example section below. To query a VSI specific association use the command option (-t) and specify the value of the VSI Instance Identifier (keywork uuid followed be the VSI UUID value) of the VSI association as configuration parameter.
- -r
- show raw client interface messages
- -R
- show only raw Client interface messages
- -W
- Wait for the bridge response message
VSI Parameter
Each VDP22 TLVs contains a command mode, manager identifier, type identifier, type identifier version, VSI instance identifier, migration hints and filter information. The fields are explained next:- mode (Command Mode):
-
The command mode determines the type
of the VSI association to be established.
It is an ascii string can be one of:
-
- assoc:
- Create an VSI association.
- preassoc:
- Create an VSI preassociation. The association is only announced to the switch.
- preassoc-rr:
- Create an VSI preassociation. The association is only announced to the switch and the switch should reserve the resources.
- deassoc:
- Delete an VSI association.
-
- mgrid2 (Manager identifier):
- The manager identifier is a string of up to 16 alphanumeric characters. It can also be an UUID according to RFC 4122 with optional dashes in between.
- typeid (Type Identifier):
- The type identifier is a number in the range of 0 to 2^24 - 1.
- typeidver (Type Identifier Version):
- The type identifer version is a number in the range of 0 to 255.
- uuid (VSI Instance Identifier):
- The VSI instance identifier is an UUID according to RFC 4122 with optional dashes in between.
- hints (Migration Hints):
-
The migration hints is a string aiding in
migration of virtual machines:
-
- none:
- No hints available.
- from:
- The virtual machine is migrating away.
- to:
- The virtual machine is migrating to.
-
- fid (Filter Information Data):
-
The filter information data can be supplied in four
different formats identified by numbers in parathesis.
Multiple filter information fields can be supplied,
but all have to be of the same format.
-
- vlan (1)
- A vlan number only, also known as filter information format 1. The vlan identifier is a number in the range of 1 to 2^16 - 1. The high order 4 bits are used as quality of service bits. The vlan identifier can be zero, a vlan identifier is then selected by the switch. Refer to IEEE 802.1 Qbg ratified standard for details.
- vlan-mac (2)
- A vlan number and MAC address delimited by a slash ('-'), also known as filter information format 2. The MAC address is specified in the format xx:xx:xx:xx:xx:xx. The colons are mandatory. For vlan details see (1).
- vlan-mac-group (4)
- A vlan number, MAC address and group identifier, each delimited by a slash ('-'), also known as filter information format 4. The group identifier is a 32 bit number. For vlan and MAC address details see (1) and (2).
- vlan--group (3)
- A vlan number and group identifier, delimited by two slashes ('--'), also known as filter information format 3. For vlan and group details see (1) and (4).
-
- oui (Organizationally Unique Identifier):
-
This defines the optional Organizationally
defined information field. This contains the
specific sets of values for this entry. There
can be multiple organizational specific fields,
in which case there will be multiple keywords
oui=
followed by the values.
The value is of the following format:
oui=OUI,[Organization specific values ]
The OUI specifies the name of the Organization
that is responsible for defining
this content. A comma is mandatory after the OUI
field. The fields following this
is specified by the organization and hence will be decoded based on the value of this OUI field. Currently, the following values for OUI are supported. -
- cisco
- Specifies Cisco defined OUI.
-
COMMANDS
- license
- show license information
- -h, help
- show usage information
- -v, version
- show version information
- -t, get-vsi
- get VSI information for the specified interface
- -T, set-vsi
- set VSI information for the specified interface
- -p, ping
- display the process identifier of the running lldpad process
- -q, quit
- exit from interactive mode
NOTES
This tool is in its early design and development phase. It it buggy, incomplete and most of the ideas have not even been thought of.... It reflects the current state of development when I had been given another work assignment. I append it so some else can continue to work on this.EXAMPLES
- Display process identifier of lldpad
-
vdptool -p - Create a VSI association on interface eth2
-
vdptool -i eth2 -T -V assoc -c mode=assoc -c mgrid2=blabla \ -c typeid=5 -c uuid=1122 -c typeidver=4 -c hints=none \ -c filter=2-52:00:00:11:22:33-200
- Create a VSI association on interface eth2 and wait for the
-
response from the bridge
vdptool -i eth2 -T -W -V assoc -c mode=assoc -c mgrid2=blabla \ -c typeid=5 -c uuid=1122 -c typeidver=4 -c hints=none \ -c filter=0-52:00:00:11:22:33-200
- Create a VSI association on interface eth2 wth OUI parameters
-
and wait for the response from the bridge
vdptool -i eth2 -T -W -V assoc -c mode=assoc -c mgrid2=blabla \ -c typeid=5 -c uuid=1122 -c typeidver=4 -c hints=none \ -c filter=0-52:00:00:11:22:33-200 -c oui=CompanyA,data
- Create a VSI association on interface eth2 wth multiple OUI parameters
-
and wait for the response from the bridge
vdptool -i eth2 -T -W -V assoc -c mode=assoc -c mgrid2=blabla \ -c typeid=5 -c uuid=1122 -c typeidver=4 -c hints=none \ -c filter=0-52:00:00:11:22:33-200 -c oui=CompanyA,data \ -c oui=CompanyB,data
- Query all VSI association on interface eth2
-
vdptool -i eth2 -t -V assoc - Query VSI association on interface eth2 that matches specific
-
VSI parameters. Any of the VSI parameters below can be omitted.
vdptool -i eth2 -t -V assoc -t -V assoc -c mode=assoc \
-c mgrid2=blabla -c typeid=5 -c uuid=1122 \
-c typeidver=4 -c hints=none
COPYRIGHT
vdptool - VSI configuration utility- Copyright(c)
- (c) 2014 IBM Corporation. Portions of vdptool are based on:
- open-lldp-0.96
- lldptool - LLDP agent configuration utility
- Copyright(c)
- 2007-2012 Intel Corporation. Portions of lldptool are based on:
- hostapd-0.5.7
- Copyright
-
(c) 2004-2008, Jouni Malinen <j@w1.fi>
LICENSE
This program is free software; you can redistribute it and/or modify it under the terms and conditions of the GNU General Public License, version 2, as published by the Free Software Foundation.This program is distributed in the hope it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
The full GNU General Public License is included in this distribution in the file called "COPYING".
SUPPORT
Contact Information: open-lldp Mailing List <lldp-devel [at] open-lldp.org>