Skip to content
Snippets Groups Projects
wrs-user-manual.in 145 KiB
Newer Older
\input texinfo    @c -*-texinfo-*-
%
% wrs-user-manual.in - main file for the documentation
%
%%%%

%------------------------------------------------------------------------------
%
%                         NOTE FOR THE UNAWARE USER
%                         =========================
%
%    This file is a texinfo source. It isn't the binary file of some strange
%    editor of mine. If you want ASCII, you should "make wrs-user-manual.txt".
%
%------------------------------------------------------------------------------

%
% This is not a conventional info file...
% I use three extra features:
%   - The '%' as a comment marker, if at beginning of line ("\%" -> "%")
%   - leading blanks are allowed (this is something I cannot live without)
%   - braces are automatically escaped when they appear in example blocks
%

@comment %**start of header
@documentlanguage en
@documentencoding ISO-8859-1
@setfilename wrs-user-manual.info
@settitle wrs-user-manual
@iftex
@afourpaper
@end iftex
@paragraphindent none
@comment %**end of header
This document is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.
@end copying
@set update-month June 2023
@c the release name below is substituted at build time
@set release __RELEASE_GIT_ID__

@comment %**useful declaration used in the document
@set release_version 6.1
@set release_version_tiny 0
@set url_docs https://www.ohwr.org/project/wr-switch-sw/wikis/Documents#files

@finalout

@titlepage
@title White Rabbit Switch: User's Manual
@subtitle Information about configuring the White Rabbit switch, for final users
@subtitle @value{update-month} (@value{release})
@author J-C. Bau, G. Daniluk, M. Lipinski, B. Rat, A. Rubini,
@author F. Vaga, A. Wujek
@insertcopying
@end titlepage
@headings single

@c ##########################################################################
@iftex
@contents
@end iftex

@c ##########################################################################
@c Top node is not included in tex
@unnumbered Introduction

The White Rabbit switch (or @sc{wrs}) is a major component of the
White Rabbit (@sc{wr}) network.  Like any modern managed switch, the
@sc{wrs} includes a CPU with its own operating system.

This manual is for people installing @sc{wrs} devices, who need to
configure them in their network.

@c ##########################################################################
@node WRS Documentation
@chapter WRS Documentation

Up to and including release v4.0 of @sc{wrs} software this manual
didn't exist, and the ``WRS Build Manual'' included some information
about configuration.

@c ==========================================================================
@node The Official Manuals
@section The Official Manuals

This is the current set of manuals that accompany the @sc{wrs}:

@itemize @bullet

@item @i{White Rabbit Switch: Startup Guide}: hardware installation
   instructions. This manual is provided by the manufacturer: it describes
   handling measures, the external connectors, hardware features and the
   initial bring-up of the device.

@item @i{White Rabbit Switch: User's Manual}: documentation about
   configuring the @sc{wrs}, at software level.  This guide is maintained
   by software developers.  The manual describes
   configuration in a deployed network, either as a standalone device or
   as network-booted equipment.  The guide also describes how to upgrade
   the switch, because we'll release new official firmware images over
   time, as new features are implemented.

@item @i{White Rabbit Switch: Developer's Manual}: it describes the
   build procedure and how internals work; use of scripts and
   @sc{wrs}-specific programs etc.  The manual is by developers
   and for developers.  This is the
   document to check if you need to customize your @i{wrs} rebuild
   software from new repository commits that are not an official release
   point, or just install your @i{wrs} with custom configuration values.

@item @i{White Rabbit Switch: Failures and Diagnostics}: describes various
   failure scenarios of a switch and ways how to recognize them.
   Additionally, it describes SNMP exports of a switch (@t{WR-SWITCH-MIB}).
@item @i{White Rabbit Switch: Radius Vlan}: describes functionality and usage
   of Radius Vlan which is a subset of IEEE 802.1X.
   When a devices is detected on a configured port, a Radius server is queried
   for authorization.

The official @sc{pdf} copy of these manuals at each release
is published in the @i{files} tab of the software project in @t{ohwr.org}:
(@uref{@value{url_docs}})).
This doesn't apply to release v4.0 and earlier.
The source form of all four manuals is maintained in @t{wr-switch-sw/doc}.
Within the repository, three of them the @i{User's Manual},
the @i{Developer's Manual} and the @i{Failures and Diagnostics}
are always tracking the software commits, while the @i{Startup Guide} may not
be authoritative because it is bound to device shipping rather than software
development.

@c ==========================================================================
@node Supported Hardware Versions
@section Supported Hardware Versions

This document applies to versions 3.3 and 3.4 of the @sc{wrs}
device.

Very few specimens of @t{wrs} 3.0 though 3.2 were manufactured; if you
are the owner of one of them, please refer to version 3.3 of the
@i{wrs-build} document, that includes appendixes about using older
versions. As usual, it is in the @i{files} tab of 
@t{@uref{@value{url_docs}}}.

V1 and V2 were development items, never shipped.


@c ##########################################################################
@node Upgrading WRS Software
@chapter Upgrading WRS Software

The @sc{wrs} is shipped with a current version of its software image,
which is sometimes called @i{firmware}.
If your devices are running a previous version of the software you may
want to upgrade, or you may want to replace the firmware images after
rebuilding your own, as explained in the @i{Developer's Manual}.

If you run version 4.1 or later please copy @t{wrs-firmware.tar} file into
the @t{/update} partition via @t{scp} or web-interface and restart your switch.

When the running version during the update is at least v5.0, then update script
performs the check of md5 sums of all files inside the @t{wrs-firmware.tar}.
If at least one checksum is incorrect, the update is aborted and an error is
reported via SNMP (object @t{wrsFwUpdateStatus}) until the next successful update.
Additionally, the @t{wrs-firmware.tar} containing corrupted file is renamed to
@t{wrs-firmware.tar.checksum_error}. This file is automatically removed during
the next successful update.

When checksums in the @t{wrs-firmware.tar} are not available
(for example during downgrading to version pre-v5.0) appropriate warning
message is printed to the console.
If this method of upgrading firmware works for you, you can ignore the rest of
this chapter, which
explains a transition between the initial way we passed MAC addresses
and the safer approach we introduced in v4.1

@c ==========================================================================
@node Upgrade from v6.0.x to v@value{release_version}
@section Upgrade from v6.0.x to v@value{release_version}
Apart from the instructions in the previous section, there
is no special action needed from the user when upgrading firmware from
v6.0.x to v@value{release_version}.

The most important changes introduced in v6.1 are:
@itemize
@item Display information about GrandMaster in @t{wr_mon}
@item Informing about unrecognized SFP in @t{wr_mon}
@item Improved reporting of offset between NTP and WR time via SNMP
@item Support of disabling SFP's TX laser with @t{wrs_sfp_dump}
@item Fixes in handling of SFP's diagnostics (if SFP diagnostic is used with
      firmware v6.0.x it can corrupt SFP's eeprom!)
@item Detection whether a switch is a low-jitter version (displayed in
      @t{wrs_version}, SNMP and web interface), and fix to leap-seconds.list update
@item Addition of a subset of IP-MIB, BRIDGE-MIB and QBRIDGE-MIB objects
      to SNMP support
@item Implementation of @t{sysObjectID} OID value to reflect WRS manufacturer and
@item Implementation of radius-802.1X for MAC authentication (subset of IEEE 802.1X)
@item Support of LLDP with VLANs
@end itemize

The following configuration items were added to the dot-config:
@itemize
@item LLDP related
@itemize
@item @t{CONFIG_VLANS_PORT@i{xx}_LLDP_TX_VID}
@item @t{CONFIG_VLANS_PORT@i{xx}_LLDP_TX_PRIO}
@end itemize

@item Radius related:
@itemize
@item @t{CONFIG_RVLAN_ENABLE}
@item @t{CONFIG_RVLAN_PMASK}
@item @t{CONFIG_RVLAN_AUTH_VLAN}
@item @t{CONFIG_RVLAN_NOAUTH_VLAN}
@item @t{CONFIG_RVLAN_OBEY_DOTCONFIG}
@item @t{CONFIG_RVLAN_RADIUS_SERVERS}
@item @t{CONFIG_RVLAN_RADIUS_SECRET}
@end itemize

@item SNMP related:
@itemize
@item @t{CONFIG_SNMP_SYSCONTACT}
@item @t{CONFIG_SNMP_SYSLOCATION}
@end itemize

@item @t{CONFIG_PPSGEN_FR_ON_SYNC_ONLY}
@end itemize

Firmware v6.1 uses the same GW as v6.0.x, so the calibration values remain
the same.

Please note that Web interface remains disabled by default.

@c ==========================================================================
@node Upgrade from v5.0.1 to v6.0.x
@section Upgrade from v5.0.1 to v6.0.x

Apart from the instructions in the introduction to this chapter, there
is no special action needed from the user when upgrading firmware from
v5.0.1 to v6.0.x. Yet, special attention should be payed
to a number of improvements in configuration and slight changes in
the behavior of the WR Switch. Here are highlights:
@itemize

@item @b{IP address of the management port}

  WR switch running the default configuration file included in the v6.0 release
  will try to get dynamic IP address for the management port at boot time.
  In case the DHCP server is not responding, WR switch will use default static
  IP assignment:
  @smallexample
  IP address: 192.168.1.254
  Netmask:    255.255.255.0
  Network:    192.168.1.0
  Broadcast:  192.168.1.255
  Gateway:    192.168.1.1
  @end smallexample
  
@item @b{Low Phase Drift Calibration (LPDC)}

  Low Phase Drift Calibration is a new feature added in release v6.0 that
  improves phase stability between WR switch restarts to <10ps. Due to FPGA
  limitations this functionality is present only on ports 1-12. 
  The LPDC requires an additional, automated calibration procedure to run for Tx
  and Rx path of each affected FPGA transceiver. The Tx calibration is performed
  once for all ports at startup of the WR switch. The Rx calibration is performed
  each time a link goes up on a port. Both Tx and Rx calibration is indicated by
  blinking of @i{Link/WR Mode} LED (left).
  The downside is that the calibration makes startup of the WR switch longer.
  Similarly, the time between connecting a fiber and the link going up
  (e.g. as observed in @i{wr_mon}) is noticeably longer.

@item @b{Configuration of the WR switch} - while it was feasible to edit by
  hand the @i{dot-config} file in the pre-v6.0 firmware versions, it is
  highly discouraged now. Since the number of configuration options increased
  greatly, the @i{dot-config} file is very long and complex. Therefore,
  @b{it is highly recommended to use the menuconfig to generate the
  @i{dot-config}} (e.g.  @i{wrs_menuconfig} tool on the WR switch).
  Highlights of the changes to configuration are provided in the following 
  bullet points.

@item @b{Configuration of PTP/PPSi in menuconfig} - up to firmware
  v5.0.1, the configuration of PPSi in @i{menuconfig} was limited to a global timing
  mode (e.g. GM, BC) and per-port proto (raw, udp), rx/tx delays, role (e.g, 
  master, slave, auto) and fiber id. Any more complex configuration of PPSi had to
  be done via a custom @t{ppsi.conf} file and this was also limited. It was
  a known issue that the @i{auto} role that uses PTP's Best Master Clock
  Algorithm was not implemented correctly. We have updated PPSi fixing all known
  issues related to compliance with IEEE1588-2008 (PTPv2) and we have already
  introduced a number of new features from the IEEE1588-2019 (PTPv2.1) edition.
  This resulted in a substantial increase and reorganization of configuration 
  parameters for PPSi in @i{menuconfig} and @t{dot-config}.
  In short, the default
  behavior of Grand-Master, Free-Running Master and Boundary Clock are preserved,
  yet with different names for the configuration options which are compliant
  with the  IEEE1588-2019. Here are the highlights of the changes
  @itemize
  @item @b{Port Timing Configuration} is organized in per-port sub-menus 
    instead of a simple configuration strings. On each physical port,
    zero or one PTP Instance can configured (in future release we will allow more
    than one PTP Instance). If you do not want to use PTP on a given physical port,
    zero PTP Instances should be used. For each PTP Instance, a number of
    configuration parameters can be selected, including:
    @itemize
    @item @b{Network Protocol} - it allows to set PTP Mapping to 
      IEEE 802.3 or UPD/Ipv4, it used to be called @b{proto}
    @item @b{Delay Mechanism} - it allows to set E2P or P2P mechanism, previously
      possibly only via custom @t{ppsi.conf}
    @item @b{SNMP monitoring} - it can be disabled which was the case
      previously when @b{role} was set to @b{non-wr}
    @item @b{Profile} - it allows to chose between WR and standard PTP,
      the choice made previously via the @b{role} setting
    @item @b{Desired State} for BC or @b{BMCA mode} for GM - they replaces the
       @b{role} function for the Master/Slave/auto settings.
    @item @b{timestampCorrectionPortDS.egressLatency} - it replaces the @b{tx} delay
    @item @b{timestampCorrectionPortDS.ingressLatency} - it replaces the @b{rx} delay
    @item @b{externalPortConfigurationEnabled} - External Port Configuration is
      a new concept (optional feature) introduced in the IEEE1588-2019 (PTPv2.1)
      that legalizes what had been done in WR switches since long: manual
      assignment of the Master/Slave role per port. This option is used
      when a WR switch is set to @b{Boundary Clocks} Timing Mode. With this option
      enabled, the Best Master Clock Algorithm is disabled and each port must be
      assigned with the @b{Desired State}: Master/Slave/Passive. If External Port
      Configuration is disabled, the Best Master Clock Algorithm is used. Note
      that this option is global, i.e. it is not allowed to use it only on some
      ports.
    @item @b{MasterOnly} - MasterOnly is a new concept (optional feature) introduced
      in the IEEE1588-2019 (PTPv2.1) that legalizes per-port assignment of
      Master role, equivalent of setting role to be Master in the pre-v6.0 firmware.
      This assignment can be done on per-port basis and it coexists with the
      Best Master Clock Algorithm. This option is used when a WR switch is set
      to @b{Grand-Master}, @b{Free-Running Master}, or @b{Arbitrary Grand-Master}.
    @end itemize
  @item @b{PTP options} - it is a new sub-menu that allows to set a number
    of global PTP parameters which previously had to be modified by customizing
    @t{ppsi.conf} file. This include: domain, priority1, priority2, clockClass.
    While these parameters are pre-filled automatically depending on the Timing
    Mode, they can be overridden if need be.
  @item @b{Timing Mode} - setting timing mode provides default configuration for
    all the above-mentioned options such that the behavior of the WR switch is
    equivalent to the same Timing Mode in pre-v6.0 firmware versions. There are
    two new modes available now: @b{Arbitrary Grand-Master} and @b{Custom}. The
    @b{Arbitrary Grand-Master} mode is similar to @b{Grand-Master} but has 
    different clockClass and ARB timescale. The @b{Custom} allows full control
    over PTP settings, otherwise limited to options allowed for a given Timing
    Mode. 
  @end itemize
@item @b{Configuration of VLANs in menuconfig} - pre-v6.0 firmware provided
  limited/simplified VLAN per-port configuration that did not allow setting some
  less-common configurations, otherwise allowed by CLI (@i{wrsw_vlan}).
  As of v6.0 firmware, such more user-friendly setting is still provided by
  default, yet it can be extended by setting @b{Enable raw ports configuration}.
@item @b{New configuration options in menuconfig}
  @itemize
  @item @b{Source for a run-time replacement of leap seconds file} - the 
    leap seconds file can be now fetch from a server and updated in
    runtime.
  @item @b{PPS generation} - it is now possible to specify a number
    of aspects of the PPS generation, @b{the default configuration might be
    slightly different from the pre-v6.0 firmware}.
  @item @b{LLDP options} - it provides configuration of Link Layer Discovery
    Protocol (LLDP) which is now supported. It is enabled by default. @b{Note that
    LLDP sends Ethernet frames of approximately 200 bytes. In the worst-case,
    transmission of such frames can increase traffic latency by 0.8us
     @footnote{The maximum PTP frame size is 96 bytes which translates into 0.76us
     latency increase to the data traffic, in case the PTP frame is sent to a
     port at the same time as the data traffic frame is to be forwarded to
     this port. An additional 100 bytes of the LLDP 
     frame, translates into additional 0.8us latency introduced by protocol 
     frames.}.} If you
    do not use LLDP and latency is of concern, you should disable LLDP option.
    Alternatively consider use of the option to limit LLDP frame size to about 
    60-70 bytes.
  @item @b{Disable web interface} - web interface is now disabled by default
    @footnote{Actually, web interface is disabled by default from firmware
    v6.0.2.
    The documentation of v6.0 claimed that it was already disabled, but it was
    and considered deprecated (no effort was put in making sure it works
    properly). @b{Users are strongly discouraged from using the web interface}.
    A number of serious security vulnerabilities were found in the web interface
    (including CVE-2023-22577).
    Please note that it is still possible to enable web interface in run-time.
    @b{Users are strongly discouraged from using the web interface}.
    In exceptional cases the use of web-interface can be limited to well
    controlled networks.
@item @b{DHCP forever configuration in menuconfig} - this behavior can be set 
  for two parameters:
  @b{Management port configuration} and @b{Source for a run-time replacement
  of dot-config} (it is called @i{Force to get the URL to a dot-config via
  DHCP} in the second case). In case the DHCP server was not available, in 
  the pre-v6.0 firmware, the WR switch would start with local dot-config and
  no IP. As of v6.0, with these settings, the WR switch waits forever
  for the DHCP server to reply. This behavior was introduced to ensure that
  operational WR switches always boot with desired remote dot-config file.
  Even if, in case of a power cut, DHCP server takes longer to boot than a WR
  Switch. Unfortunately, the downside is that while waiting for the DHCP server,
  WR switch it is not accessible via
  the management port or management USB. The only way to stop the endless loop
  is to connect via the back USB (ARM Test) and follow the instructions, i.e.
  press Enter.
@item @b{Updated look of wr_mon} - this mostly commonly used Command Line 
  Interface tool in the WR switch has been updated to provide more information,
  here are the highlights:
    @itemize
    @item @b{Timing Mode}@footnote{@i{PLL mode} from firmware v6.1}
      indicates the current timing mode of the Soft PLL,
      it is not the intended @i{Timing Mode} configured in the @t{dot-config}
      file. So, a GM or BC switch will show the @b{Timing Mode} to be @i{FR}
      (free running) until it locks to the source of time, i.e. input 10MHz &
      1PPS or Slave port, respectively. 
    @item @b{PTP/EXT/PDETECT states} provides information about
      @itemize
      @item @b{PTP} - indicates the PTP state of a given port, as established
        by Best Master Clock Algorithm, or configured via External Port 
        Configuration. Note that ports which are down (not connected) are always
        placed in @i{DISABLED} state.
      @item @b{EXT} - indicates the state of the currently used extension,
        for v6.0 firmware, it is the state of the White Rabbit state machine
        (more extensions in future will be supported). In the pre-v6.0 firmware,
        the state of PTP or extension was provided in the @i{PTP state} column.
      @item @b{PDETECT} - indicates the state of a state machine that governs
        the detection of extensions. When a WR link is being established, it 
        shows @i{WA_MSG}, when it is successfully established, it shows
        @i{EXT_ON}
      @end itemize
    @item @b{Synchronization status} - most of the parameter names were replaced
      with their equivalents used in the IEEE1588 standard:
      @itemize
      @item @b{DelayMM} is the previously  @i{Round-trip time (mu)}
      @item @b{DelayMS} is the previously  @i{Master-slave delay}
      @item @b{delayAsymmetry} is the previously  @i{Total link asymmetry}
      @item @b{delayCoefficient} is the previously @i{alpha}
      @item @b{ingressLatency} is the previously @i{Slave PHY delay RX} without the bitslide
      @item @b{egressLatency}  @i{Slave PHY delay TX}
      @item @b{offsetFromMaster} is the previously @i{Clock offset}
      @item @b{semistaticLatency} is a new parameter that indicates the
            bitslide value
      @end itemize
    @end itemize
@end itemize

@c ==========================================================================
@node Upgrade from pre-v5.0 to v5.0.1 or later
@section Upgrade from pre-v5.0 to v5.0.1 or later
During the update from the pre-v5.0 firmware to v5.0.1 or later (or later) you might see
the following errors on the console.
@example
/wr/bin/sdb-read: can't load library 'libm.so.1'
Creating SDB filesystem in /dev/mtd5
cp: can't stat '/wr/etc/sdb-for-dataflash': No such file or directory
 done
@end example
Please ignore this message, no real error occurred nor @i{hwinfo} partition
(@t{/dev/mtd5}) was overwritten. The error is caused by an old firmware trying
to run a binary (@t{sdb-read} to be precise) from the new firmware image.
The problem became visible now, because between v4.2 and v5.0 we uplifted
the buildroot, which changed the version of @t{libm} library from @t{libm.so.0}
to @t{libm.so.1}.

@c ==========================================================================
@node hwinfo for pre-v4.1
@section hwinfo for pre-v4.1

Version 4.1 (October 2014) and later ones use a new way to pass
hardware information to all levels of software, such information
includes the MAC addresses for the management Ethernet and the
@sc{sfp} ports.  Information is now stored in a Flash partition called
@i{hwinfo}, using the @sc{sdb} file format. @sc{sdb} is defined in the
@t{fpga-configuration-space} within @t{ohwr.org}.  Before using
@sc{sdb} we used to edit the boot loader's configuration at flash
The @i{hwinfo} structure is written to @i{dataflash} by the manufacturer. It is
never changed even when performing a complete re-flash of the device, because
the flashing scripts preserve the @i{hwinfo} memory area.

When upgrading from a pre-4.1 switch software, you need to create this
@i{hwinfo} data structure. The procedure is mostly automatic, but you
need to be aware of the steps involved, in case something goes wrong.

@c ==========================================================================
@node Upgrading from v4.0 and later
@section Upgrading from v4.0 and later

Version 4.0 and later of @t{wr-switch-sw} are able to upgrade
Alessandro Rubini's avatar
Alessandro Rubini committed
themselves if you place the proper files in the @i{/update} directory
of the @sc{wrs}.  However, in version 4.0 we forgot to provide for
an upgrade of the boot loader and didn't note that if the front USB
cable is not plugged, the upgrade procedure blocks.
This latter problem happens because messages are written to the
management USB port, to help people flashing from scratch, and the
write is a blocking one by default: if nobody collects the USB data,
the system waits for a recipient. With version 4.1.1 the problem was fixed using
non-blocking operations (it is better to loose messages than to block the
installation because nobody is reading).

Thus, there are two different ways to upgrade; which one
you prefer we can't tell. Both work, each with its own drawbacks.
Each of them preserves the current MAC addresses.

@c =-------------------------------------------------------------------------
@node Upgrading with the USB cable
@subsection Upgrading from v4.0 with the USB cable

This is the procedure if you are able to walk to your @sc{wrs} and
connect to the management USB port, even if the port is not
actually used:
   @item Copy your own @t{wrs-firmware.tar} for at least v4.1 into the
   @i{/update} partition.
Alessandro Rubini's avatar
Alessandro Rubini committed
   This can be the official firmware or one you built yourself.
   Then reboot and wait for everything to settle (the system will reboot
   once more by itself).

   @item Copy @t{wrs-firmware.tar} again. And reboot again. The system
   will reboot once more by itself.

   @item Now you have a running updated version with your @i{hwinfo} in place
   and the old MAC addresses preserved.

@end itemize

We save you from the long description of what is happening in the
various steps. If needed, it is in the @i{git} history of @t{wr-switch-sw},
at release point @t{v4.1}.
@c =-------------------------------------------------------------------------
@node Upgrading from v4.0 remotely
@subsection Upgrading from v4.0 remotely
If you can't walk to the switch, the procedure is faster but more
commands need to be typed on the root shell of the switch.  We
support a single upgrade provided you change the kernel and initial
filesystem before rebooting.
   @item Copy your own @t{wrs-firmware.tar} for at least v4.1 into the
Alessandro Rubini's avatar
Alessandro Rubini committed
   @i{/update} partition. This can be the official firmware or one you built
   @item Create and mount @i{/boot} within the switch. This means
   running the following commands in @i{ssh}:
      @t{mkdir /boot}

      @t{mount -t ubifs ubi0:boot /boot}

   @item Copy @t{wrs-initramfs.gz} (which is to be found inside
   @t{wrs-firmware.tar}) to the @i{/boot} partition just mounted.  This
   ensures the new upgrade procedure will run, the one that doesn't block
   if the USB cable is unplugged.

   @item Copy @t{zImage} (again, to be found inside
   @t{wrs-firmware.tar}) to the @i{/boot} partition.  This is need to
   be able to access the @i{hwinfo} partition at next boot.

   @item Reboot and wait for everything to settle (the system will reboot
   once more by itself after upgrading everything).  The MAC addresses
   will be saved to @i{hwinfo} during the update procedure, thanks to
   the new kernel and new boot procedure you manually  copied to @i{/boot}.
@b{Note:} if you forget to place the new kernel or @t{wrs-initramfs.gz}
in @i{/boot}, no big damage will happen, but you'll have lost your
MAC address for the @sc{wr} ports.  You'll find a randomly-chosen value,
that will however be persistent over reboot (because it is saved to
@i{hwinfo} after you boot with the new kernel.

@c ==========================================================================
@node Upgrading from v3.x
@section Upgrading from v3.x

Upgrading from versions older than v4.0 (August 2014) requires physical
access to the device and, unfortunately, requires some extra steps
especially if you want to preserve your MAC addresses.

One possible path is flashing version 4.0 (please refer to v4.0
manuals) and then proceed as described in @ref{Upgrading from v4.0 and later}.
When flashing version 4.0 you'll need to pass your MAC addresses on
the command line of the flasher, so please take note of what they are.
Alessandro Rubini's avatar
Alessandro Rubini committed
Another option is flashing the latest firmware version and then build
your own @i{hwinfo} structure by specifying your MAC addresses.
@t{wr-switch-sw} includes specific tools for both steps. They are
described in the @i{Developer's Manual}, because they are expected to
only be performed by the manufacturer, not the final user.


@c ##########################################################################
@node Configuration of the Device
@chapter Configuration of the Device
The switch can boot embedded Linux using its internal @sc{nand} memory or as an
NFS-Root host. In the latter case is especially useful for development, when
binaries of various software daemons might need to be updated regularly.
But this option implies
some network traffic on your management network, as well as an NFS
server able to host all of your switches.

The configuration of every @sc{wrs} is described in a Kconfig-generated file.
This configuration file can be found in the filesystem of @sc{wrs} under
@t{/wr/etc/dot-config}. The switch runs by default with a configuration
provided with the stable firmware release. If you are running a small WR
network, or just a single switch for lab tests, you can modify various
settings directly from the shell or web interface. After logging to @sc{wrs}
(e.g. using @t{ssh}) you can call ``@t{wrs_menuconfig}`` command
to modify the locally stored configuration file in a convenient way.
However, this approach doesn't scale well to large installations, because if a device
needs to be replaced, its own configuration is lost.

For operational networks, it is recommended to setup
a DHCP/TFTP server for central management of configuration files and to let @sc{wrs}
download its @t{dot-config} file at boot time. This also facilitates recovering a
@sc{wr} network in case of @sc{wrs} hardware failure. It takes only a change in
the DHCP database to boot new @sc{wrs} without losing the desired configuration.
In this case, each @sc{wrs} device loads its own
configuration file each time it is booted, and applies the choices
before starting any service.  The name of the configuration file can
include the @sc{mac}, @sc{ip} address or @sc{hostname} of the device, to allow
running several switches with different configurations in the same
network. The location of the configuration file can be stored in the
@t{dot-config} or be retrieved from DHCP server.

@c ==========================================================================
@node The Configuration File
@section The Configuration File

The main configuration file for the @sc{wrs} is
@t{/wr/etc/dot-config}.  You can create this file either by running ``@t{make
menuconfig}'' within the local clone of @t{wr-switch-sw} repo or directly in the
shell of your switch (e.g. through @t{ssh}), and making your choices.
You can also edit the text file using external tools, or run other
configurators: @t{make config},
@t{make xconfig}, @t{make gconfig}, @t{make nconfig}.

The configuration step creates @t{.config}, that you can copy to your
@sc{wrs} as @t{/wr/etc/dot-config}. After reboot, you'll see your
choices in effect.

The rest of this section describes various options that are provided through the
configuration (@t{dot-config}) file.

@table @t

@item CONFIG_DOTCONF_FW_VERSION
@itemx CONFIG_DOTCONF_HW_VERSION

	Free-text items to describe switch's firmware
	@t{CONFIG_DOTCONF_FW_VERSION} and hardware
	@t{CONFIG_DOTCONF_HW_VERSION} version. Additionally, the default value
	of @t{CONFIG_DOTCONF_FW_VERSION} can be used as a version of a Kconfig
	file. These fields do not affect any functionality of the switch.
	Free-text item to describe any additional information about dot-config.
  This field does not affect any functionality of the switch.

@end table

The next configuration item is a choice about source of the @t{dot-config} file
(items starting with @t{CONFIG_DOTCONF_SOURCE_}).  The following @t{dot-config}
sources are implemented in current version:
@table @t
@item CONFIG_DOTCONF_SOURCE_LOCAL

	Use local @t{dot-config} file stored in @t{/wr/etc/dot-config}.
        In this case no network access is performed.

@item CONFIG_DOTCONF_SOURCE_REMOTE

	Get a @t{dot-config} file from the URL provided in @t{CONFIG_DOTCONF_URL}.

@item CONFIG_DOTCONF_SOURCE_FORCE_DHCP
	Get a network location of a @t{dot-config} file from a DHCP server.
        Server can be configured in a way to provide the entire URL to
        the @t{dot-config} in the ``@t{filename}'' configuration field of the
        DHCP server. In this case, provided URL has to be in the same form
        as @t{CONFIG_DOTCONF_URL}. 
        
        As an alternative, ``@t{filename}'' can be configured only as a
        path. It will be then interpreted as a path on a TFTP server, which IP
        address is taken from the configuration field
        ``@t{The BOOTP next server option}'' of a DHCP server.
        
        If the DHCP service is not available at boot time, the switch will wait
        forever until it has obtained the DHCP lease from the server. If the DHCP server is reachable 
        but switch fails to download @t{dot-config} file, it will report appropriate error over SNMP.
         
        This choice is only available if CONFIG_ETH0_DHCP is chosen for network configuration. 
        

@item CONFIG_DOTCONF_SOURCE_TRY_DHCP
	The same as @t{CONFIG_DOTCONF_SOURCE_FORCE_DHCP}, but this option does
        not trigger errors in SNMP's objects if switch fails to retrieve the
        URL to the @t{dot-config} via DHCP. Note that syntax and download
        errors of @t{dot-config} are notified in the same way as for other
        choices.

@end table

If the selected option triggers @sc{wrs} to download a new @t{dot-config}
file and it passes the validation process, the new @t{dot-config} will replace
a local copy. In case there are errors or unknown
configuration entries in the retrieved file, the old, local @t{dot-config} will be used.

The URL (stored in @t{CONFIG_DOTCONF_URL} or retrieved via DHCP) is of the form
``@i{protocol}@t{://}@i{host}@t{/}@i{pathname}''.  The special upper-case
strings @t{HOSTNAME}, @t{IPADDR} and @t{MACADDR} are substituted with the
current hostname, IP address or MAC address of the management port of the
switch. By this, the same configuration string can be used to set up a batch
of switches with different configurations.

The three parts of the URL are as follows:

@table @i

@item protocol

	We support @t{http}, @t{ftp} and @t{tftp}.  Any other protocols
        result in an error, and the @t{dot-config} file is not replaced.
	The host can be an IP address, or a name. In order to use
        a name you must specify a valid @t{CONFIG_DNS_SERVER} and
        optionally @t{CONFIG_DNS_DOMAIN}. Alternatively DNS configuration can
        be taken from the DHCP server.  The values
        in the current @t{dot-config} are used to load the new file.

@item path

	The pathname can include directory components and any of @t{HOSTNAME},
	@t{IPADDR}, @t{MACADDR}.

@end table

For example this is a valid configuration for run-time update:

@smallexample
   CONFIG_DOTCONF_SOURCE_REMOTE=y
   CONFIG_DOTCONF_URL="tftp://morgana/wrs-config-IPADDR"
   CONFIG_DNS_SERVER="192.168.16.1"
   CONFIG_DNS_DOMAIN="i.gnudd.com"
@end smallexample

It results in @t{wrs-config-192.168.16.9} being served to the @sc{wrs}.
Please remember, that the new @t{dot-config} should include a valid
@t{CONFIG_DOTCONF_SOURCE_*} setting, or you won't be able to update the
configuration at the next boot. In any case, you can always copy a
configuration file using @i{ssh}, or use the web interface to change the
configuration.
Changes performed using the web interface are immediately active, because
the web server takes proper action; the new file copied over with @i{ssh},
or any hand-edits, are only effective at next boot, unless overwritten by
a remote configuration file.
In case there are errors or unknown configuration entries in the retrieved
file, the old one will be used.

@c ==========================================================================
@node Configuration Items that Apply at Build Time
@section Configuration Items that Apply at Build Time
The following items in @t{dot-config} are used at build time; changing
them in the running switch has no effect:

@table @code

@item CONFIG_BR2_CONFIGFILE

	This string option lists a file to be used as Buildroot (BR2)
        configuration. A simple filename or relative pathname refers to the 
        @t{configs/buildroot} directory; an absolute pathname is used
        unchanged.

@item CONFIG_KEEP_ROOTFS

	A boolean option for developers: if set the build script does
        not delete the temporary copy of the generated filesystem and
        reports its pathname in the build messages.

@end table

@c ==========================================================================
@node Configuration Items that Apply at Run Time
@section Configuration Items that Apply at Run Time

The following items in @t{dot-config} are used at run time: at every
boot the value (the old one or the just-downloaded one) is used in the
appropriate way, before the respective service is started.
@c When the value is changed by the web interface, proper action is taken.
@item CONFIG_DOTCONF_SOURCE_LOCAL
@itemx CONFIG_DOTCONF_SOURCE_REMOTE
@itemx CONFIG_DOTCONF_SOURCE_FORCE_DHCP
@itemx CONFIG_DOTCONF_SOURCE_TRY_DHCP
@itemx CONFIG_DOTCONF_URL
	The source and location of a config file to be used at a replacement
        the next time the system boots. See @ref{Configuration of the Device}
        and @ref{The Configuration File} for details.

@item CONFIG_LEAPSEC_SOURCE_LOCAL
@itemx CONFIG_LEAPSEC_SOURCE_REMOTE_FORCE
@itemx CONFIG_LEAPSEC_SOURCE_REMOTE_TRY
@itemx CONFIG_LEAPSEC_URL
	The @t{/etc/leap-seconds.list} file is used to get the current TAI offset. @xref{wr_date}.
	The @t{CONFIG_LEAPSEC_SOURCE_LOCAL} choice forces the use the local leap seconds file that
  is stored locally on the switch (under @t{/etc/leap-seconds.list}). 
	
	@t{CONFIG_LEAPSEC_SOURCE_REMOTE_FORCE} and @t{CONFIG_LEAPSEC_SOURCE_REMOTE_TRY} provide
  similar functionality. In both cases the @t{leap-seconds.list} is downloaded at boot
  time using the URL defined in @t{CONFIG_LEAPSEC_URL}. The address is defined in the
  same format as @t{CONFIG_DOTCONF_URL}. If the downloaded file is newer than the
  local copy stored in @t{/etc/leap-seconds.list}, it is used to update the local
  copy.
  In case the @sc{wrs} is unable to fetch a leap seconds file from the provided location,
  using @t{CONFIG_LEAPSEC_SOURCE_REMOTE_FORCE} will result in an error generated through
  SNMP, while using @t{CONFIG_LEAPSEC_SOURCE_REMOTE_TRY} will suppress the alarm.

@item CONFIG_ETH0_DHCP
@itemx CONFIG_ETH0_DHCP_ONCE
@itemx CONFIG_ETH0_STATIC

	Configuration of management port's (@t{eth0}) IP. When
	@t{CONFIG_ETH0_DHCP} is used, then switch tries to obtain IP via DHCP
	forever. For option @t{CONFIG_ETH0_DHCP_ONCE} switch tries to get IP
	via DHCP once, if this try is unsuccessful then switch uses static IP.
	@t{CONFIG_ETH0_STATIC} forces switch to use provided static IP address.

@item CONFIG_ETH0_IP
@itemx CONFIG_ETH0_MASK
@itemx CONFIG_ETH0_NETWORK
@itemx CONFIG_ETH0_BROADCAST
@itemx CONFIG_ETH0_GATEWAY

	Management port's (@t{eth0}) static IP configuration when
	@t{CONFIG_ETH0_DHCP_ONCE} or @t{CONFIG_ETH0_STATIC} parameter is used.

@item CONFIG_HOSTNAME_DHCP
@itemx CONFIG_HOSTNAME_STATIC
@itemx CONFIG_HOSTNAME_STRING

	These options describe how to set hostname of the switch. From DHCP
	(@t{CONFIG_HOSTNAME_DHCP}) or use a predefined value
	(@t{CONFIG_HOSTNAME_STATIC}) defined in option @t{CONFIG_HOSTNAME_STRING}.

@item CONFIG_ROOT_ACCESS_DISABLE

	Disable root access via ssh. With this option enabled it is still
	possible to use sudo to get root privileges.

@item CONFIG_LDAP_ENABLE
@itemx CONFIG_LDAP_SERVER
@itemx CONFIG_LDAP_SEARCH_BASE
@itemx CONFIG_LDAP_FILTER_NONE
@itemx CONFIG_LDAP_FILTER_EGROUP
@itemx CONFIG_LDAP_FILTER_CUSTOM
@itemx CONFIG_LDAP_FILTER_EGROUP_STR
@itemx CONFIG_LDAP_FILTER_CUSTOM_STR

        Set of options related to providing an authorization via LDAP for ssh.
        To be able to use LDAP please enable an option @t{CONFIG_LDAP_ENABLE},
        provide LDAP server (@t{CONFIG_LDAP_SERVER}) and the search base
        (@t{CONFIG_LDAP_SEARCH_BASE}). It is possible to limit the access
        to a particular e-group used at CERN (@t{CONFIG_LDAP_FILTER_EGROUP}
        to enable and @t{CONFIG_LDAP_FILTER_EGROUP_STR} to provide
        the e-group's name) or to provide the custom filtering string
        (@t{CONFIG_LDAP_FILTER_CUSTOM} to enable and
        @t{CONFIG_LDAP_FILTER_CUSTOM_STR} to provide the filter).
        For more information please refer to the @i{Kconfig}'s help.


@item CONFIG_AUTH_LDAP
@itemx CONFIG_AUTH_KRB5
@itemx CONFIG_AUTH_KRB5_SERVER

        Choose the authentication method. @t{CONFIG_AUTH_LDAP} for LDAP
        authentication, @t{CONFIG_AUTH_KRB5} for Kerberos authentication.
        For the later one it is obligatory to specify Kerberos Realm
        in @t{CONFIG_AUTH_KRB5_SERVER}.
@item CONFIG_ROOT_PWD_IS_ENCRYPTED
@itemx CONFIG_ROOT_PWD_CLEAR
@itemx CONFIG_ROOT_PWD_CYPHER

	This set of options allows setting the password for the ``root''
        user (the administrator). The password is used to login to
        your switch using @t{ssh} (secure shell).  If you choose
        @t{CONFIG_ROOT_PWD_IS_ENCRYPTED}, you will be prompted for a
        text version of a pre-encrypted password (@t{CONFIG_ROOT_PWD_CYPHER}).
        To encrypt your @i{magic} string, you must run ``@t{mkpasswd
	--method=md5} @i{magic}'' on your Linux host (or switch).
        If you choose to configure an unencrypted password, then you are
        asked to specify it as @t{CONFIG_ROOT_PWD_CLEAR}. In this latter
        case encryption is performed at run-time to use the normal @i{ssh}
        authentication, but the clear-text password will remain in
        @t{dot-config}.
        By default the root password is an empty string, like in the initial
        @i{wr-switch-sw} releases.

@item CONFIG_NTP_SERVER

	The NTP server used to prime White Rabbit time, at system boot.
        The option can be an IP address or a host name, if DNS is properly
        configured.  The configuration value is stored in
        @t{/etc/wr_date.conf}. An empty string (default) disables
        NTP access at boot time.

@item CONFIG_DNS_SERVER
@itemx CONFIG_DNS_DOMAIN

	The DNS server (as an IP address) and default domain. The values
        end up in @t{/etc/resolv.conf} of the runtime filesystem.
        By default the two strings are empty. If @t{CONFIG_ETH0_DHCP} or
        @t{CONFIG_ETH0_DHCP_ONCE} is used, @t{/etc/resolv.conf} file will be
        populated with DNS settings received from the DHCP server.
        If configuration items for static (@t{CONFIG_DNS_*}) and dynamic
        (@t{CONFIG_ETH0_DHCP}) DNS configuration are used simultaneously
        then information from both sources end up in the @t{/etc/resolv.conf}
        file. However, information from @t{CONFIG_DNS_*} is placed first.

@item CONFIG_REMOTE_SYSLOG_SERVER
@itemx CONFIG_REMOTE_SYSLOG_UDP
@itemx CONFIG_LOCAL_SYSLOG_FILE
	Configuration for system log. The name (or IP address) of the
        server is stored in @t{/etc/rsyslog.conf} of the runtime
        filesystem.  The UDP option, set by default, chooses UDP transmission;
        if unset it selects TCP communication.
	    @t{CONFIG_LOCAL_SYSLOG_FILE} option indicates the file to which
      syslog messages will be stored in a local filesystem of the @sc{wrs}.
	The file is rotated when reaching 1MB. The rotation is done through 10
	indexed files @i{syslog}, @i{syslog.1-9}. By default these files are
	created in @i{/tmp} folder.
	If remote server is specified, the messages go to both, server and local file.

@item CONFIG_WRS_LOG_HAL
@itemx CONFIG_WRS_LOG_RTU
@itemx CONFIG_WRS_LOG_PTP
@itemx CONFIG_WRS_LOG_OTHER

	Logging options for the three main WRS processes and other programs.
	@t{CONFIG_WRS_LOG_OTHER} is currently used by:
	@itemize
	@item @t{wrs_watchdog} daemon
	@item @t{wrs_throttling} executed once at boot up
	@item @t{wrs_auxclk} executed once at boot up
	@item @t{wrs_custom_boot_script.sh} executed once at boot up
	@item Setting VLANs with @t{vlan.sh} at boot up
        can be a pathname, either to a file (e.g. @t{/dev/kmsg}
        is a possible ``file'' target) or a @i{facility}.@i{level} string,
        like @t{daemon.debug}, for syslog-based logging.
        An empty string suppresses all logging for a given daemon.  Please note, that
        unknown facility names will generate a runtime error on the switch.
        All four strings default to ``@t{daemon.info}''.
	@b{Note:} all messages produced by these programs if syslog is
	configured will be passed to the syslog at the same
	configured @i{<facility>.<level>}, no matter the verbosity of a message.
	To change the verbosity of programs please use
	@t{CONFIG_WRS_LOG_LEVEL_*}.

@item CONFIG_WRS_LOG_LEVEL_HAL
@itemx CONFIG_WRS_LOG_LEVEL_RTU
@itemx CONFIG_WRS_LOG_LEVEL_OTHER

	Specify verbosity of programs as a string or number. The following
	levels are supported:
	@itemize
	@item @t{ALERT} or 1
	@item @t{ERROR} or 3
	@item @t{WARNING} or 4
	@item @t{INFO} or 6
	@item @t{DEBUG} or 7
	@end itemize
	Not supported levels are ceiled to the valid one.

	By leaving this item empty, programs will use its default verbosity
	level (@t{INFO}).

	@b{Note:} all messages produced by these programs if syslog is
	configured will be passed to the syslog at the same
	configured @i{<facility>.<level>}, no matter of verbosity of a message.

@item CONFIG_WRS_LOG_LEVEL_PTP

	Specify verbosity of PPSi daemon as a string. This string will be
	passed to the PPSI after @t{-d} parameter. Please refer to the PPSI's
	documentation for more details.

	By leaving this item empty, PPSi daemon will use its default
	verbosity level.
	
	@b{Note:} all messages produced by PPSi if syslog is
	configured will be passed to the syslog at the same
	configured @i{<facility>.<level>}, no matter of verbosity of a message.

	Value can be a pathname, either to a file (e.g. 
        @t{/dev/kmsg} is a possible ``file'' target) or a valid snmpd log
        option (without -L).
        Allowed strings are in the format ``@t{S} @i{level} @i{facility}'' (e.g.
        ``@t{S 2 daemon}''). For example, ``@t{s daemon}'' will forward
        messages to syslog with daemon as facility. To set level (i.e. 5) use
	``@t{S 5 daemon}''. For details please check @t{man snmpcmd}. An empty
	string turns suppresses all logging. Please note that unknown facility
	names will generate a runtime error on the switch.

  @b{Note:} It looks
	like @t{Notice} is not a default logging priority as written in
	@i{net-snmp} manual.
@item CONFIG_WRS_LOG_MONIT
	The string can be a pathname (e.g. @t{/dev/kmsg}) or a @t{syslog}
	string.
	An empty string is used to represent no logging. If it is needed to
	select facility and level please leave an empty string here and change
	@t{/etc/monitrc} or @t{/usr/etc/monitrc} file directly.
	Please note that unknown facility names will generate a runtime error
	on the switch.
@item CONFIG_PTP_OPT_EXT_PORT_CONFIG_ENABLED
@itemx CONFIG_PORT@i{xx}_@i{zz}
	These configuration items are used to set up timing parameters of all
	WR ports. 
	Items are named according to the format  @t{CONFIG_PORT@i{xx}_@i{zz}} where : 
		@item @i{xx} -- represents the port number ('01' to '18')
		@item @i{zz} -- is the property name for the given port @i{xx} 
    The default configuration provided with the firmware release will
    most likely work for the majority of @sc{wr} networks. In case some
    customization of these parameters is required, please see
    @ref{Timing Configuration} for details.
@item CONFIG_N_SFP_ENTRIES
@itemx CONFIG_SFP00_PARAMS
@itemx CONFIG_SFP17_PARAMS

   Configuration for @sc{sfp} models.
   
   @t{CONFIG_N_SFP_ENTRIES} indicates the number of SFP entries defined. Up to 18 SFPs
   can be defined. 
    
   @t{CONFIG_SFP@i{xx}_PARAMS} with index @i{xx} in range 00 to 17, contains @sc{sfp} parameters.
	 All @sc{sfp} models their respective wavelengths you are using in your @sc{wrs}
   should be entered here.
	@itemize
		@item @t{vn} (@i{optional}) -- Vendor Name of an SFP
		@item @t{pn} -- Part Number of an SFP
		@item @t{vs} (@i{optional}) -- Vendor Serial (serial number) of
					       an SFP
		@item @t{tx} -- TX delay of an SFP in picoseconds
		@item @t{rx} -- RX delay of an SFP in picoseconds
		@item @t{wl_txrx} -- Tx wavelength separated by "+" with Rx
				     wavelength of an SFP;
				     for example @t{wl_txrx=1490+1310} (for
				     1490nm Tx wavelength and 1310nm Rx
				     wavelength)
        @end itemize
        See @ref{Timing Configuration} for details.
@item CONFIG_N_FIBER_ENTRIES
@item CONFIG_FIBER00_PARAMS
@itemx ...
@itemx CONFIG_FIBER17_PARAMS
	These parameters specify the characteristics of fiber types used in your @sc{WR} installation.
	@t{CONFIG_N_FIBER_ENTRIES} indicates the number of fiber types defined. Up to 18 
	different fiber types can be defined. 
   
	@t{CONFIG_FIBER@i{xx}_PARAMS} with index @i{xx} in range 00 to 17, specifies
  the alpha value for each pair of used wavelengths.
	This parameter follows the format:
	@t{alpha_@i{xxxx}_@i{yyyy}=1.23e-04,alpha_@i{aaaa}_@i{bbbb}=4.56e-04,...}
	@item @t{@i{xxxx}_@i{yyyy}} and @t{@i{aaaa}_@i{bbbb}} are pairs of used wavelengths
	@item @t{1.23e-04} and @t{4.56e-04} are alpha values to be used for
	      a particular combination of wavelengths.
	The index (@t{00} to @t{17}) is then entered as @t{CONFIG_PORT@i{xx}_FIBER}
  port parameter to reference the connected fiber type.
  @xref{Timing Configuration}.
	You are expected to have no more than 18 fiber types installed in
	your @sc{WR} network.
@itemx CONFIG_TIME_ARB_GM
@itemx CONFIG_TIME_FM
@itemx CONFIG_TIME_BC
@itemx CONFIG_TIME_CUSTOM
	The type of PTP clock this switch is. Only one of the five first
        items should be set (e.g. running ``@t{make menuconfig}'' offers
        them as an exclusive choice). The options select: 
        @itemize 
	        @item @t{CONFIG_TIME_GM} a grand-master with external reference, e.g. GPS or Cesium.
	        @item @t{CONFIG_TIME_ARB_GM} a arbitrary grand-master which designates 
	        	a clock that is synchronized to an application-specific source of time. 
	        @item @t{CONFIG_TIME_FM} a free-running master (FM), used for isolated 
	        	acquisition networks, without an external reference. 
	        @item @t{CONFIG_TIME_BC} a normal ``boundary-clock'' device that
	        	is slave on some ports and master on other ports.  
 	        @item @t{CONFIG_TIME_CUSTOM} an option which leaves the possibility
            to define freely the PTP clock class.
@item CONFIG_PTP_OPT_DOMAIN_NUMBER
	A domain consists of one or more PTP devices communicating with each
	other as defined by the PTP protocol. A domain defines the scope of
	PTP message communication, state, operations, data sets, and
	timescale. PTP devices may participate in multiple domains.
	For more details please refer to the IEEE 1588-2008 standard.

@item CONFIG_PTP_OPT_PRIORITY1
	A user configurable designation that a clock belongs to an ordered
	set of PTP devices from which a PTP Master is selected.
	For more details please refer to the IEEE 1588-2008 standard.

@item CONFIG_PTP_OPT_PRIORITY2
	A user configurable designation that provides finer grained ordering
	among otherwise equivalent PTP devices.
	For more details please refer to the IEEE 1588-2008 standard.

@item CONFIG_PTP_OPT_CLOCK_CLASS
	An attribute defining the TAI traceability, synchronization state and
	expected performance of the time or frequency distributed by a
	Boundary Clock or Ordinary Clock.
	Its value can be set only if @t{CONFIG_TIME_CUSTOM} parameter is selected.
  The following table shows the default values
	used depending on the timing mode ''@t{CONFIG_TIME_@i{xx}}'' choice:
		@multitable @columnfractions .3 .4
		@headitem  Timing mode @tab CONFIG_PTP_OPT_CLOCK_CLASS 
		@item  CONFIG_TIME_GM @tab 6
		@item  CONFIG_TIME_ARB_GM @tab 13
		@item  CONFIG_TIME_FM @tab 193
		@item  CONFIG_TIME_BC @tab 248
		@end multitable

	For more details please refer to the IEEE 1588-2008 standard.

@item CONFIG_PTP_OPT_CLOCK_ACCURACY
	An attribute defining the accuracy of the Local Clock (e.g. local
	oscillator) of a Boundary Clock or Ordinary Clock.
	Its value is set automatically according to the timing mode ''@t{CONFIG_TIME_@i{xx}}'' choice.
	It can be also manually set when either @t{CONFIG_PTP_OPT_OVERWRITE_ATTRIBUTES} is set 
	or the timing mode ``@t{CONFIG_TIME_CUSTOM}`` is selected.
	The following table gives the default values depending on the timing mode
  ''@t{CONFIG_TIME_@i{xx}}'' choice :
		@multitable @columnfractions .3 .4
		@headitem  Timing mode @tab CONFIG_PTP_OPT_CLOCK_ACCURACY 
		@item  CONFIG_TIME_GM @tab 33
		@item  CONFIG_TIME_ARB_GM @tab 33
		@item  CONFIG_TIME_FM @tab 32
		@item  CONFIG_TIME_BC @tab 254
		@end multitable
	For more details please refer to the IEEE 1588-2008 standard.
	
@item CONFIG_PTP_OPT_CLOCK_ALLAN_VARIANCE
	An attribute defining the stability of the Local Clock of a
	Boundary Clock or Ordinary Clock.
	Its value is set automatically according to the timing mode ''@t{CONFIG_TIME_@i{xx}}'' choice.
	It can be also manually set either @t{CONFIG_PTP_OPT_OVERWRITE_ATTRIBUTES} is set 
	or the timing mode ``@t{CONFIG_TIME_CUSTOM}`` is selected.
	The following table gives the default values depending on the timing mode
  ''@t{CONFIG_TIME_@i{xx}}'' choice :
		@multitable @columnfractions .3 .4
		@headitem  Timing mode @tab CONFIG_PTP_OPT_CLOCK_ALLAN_VARIANCE 
		@item  CONFIG_TIME_GM @tab 47360
		@item  CONFIG_TIME_ARB_GM @tab 47360
		@item  CONFIG_TIME_FM @tab 50973
		@item  CONFIG_TIME_BC @tab 65535
		@end multitable

	For more details please refer to the IEEE 1588-2008 standard.


@item CONFIG_PTP_OPT_TIME_SOURCE
	This information-only attribute indicates the source of time used
	by the grandmaster or free-running master. In case the timing mode is set to
  ``@t{CONFIG_TIME_BC}`` this configuration option is not used and thus hidden
  from options available e.g. through ``@t{make menuconfig}''.
	The following table gives the default values depending on the timing mode
  ''@t{CONFIG_TIME_@i{xx}}'' choice :
		@multitable @columnfractions .3 .4
		@headitem  Timing mode @tab CONFIG_PTP_OPT_TIME_SOURCE 
		@item  CONFIG_TIME_GM @tab 32 (GNSS)
		@item  CONFIG_TIME_ARB_GM @tab 32 (GNSS)
		@item  CONFIG_TIME_FM @tab 160 (INTERNAL_OSCILLATOR)
		@item  CONFIG_TIME_BC @tab --
		@end multitable
		
@item CONFIG_PTP_PORT_PARAMS
@itemx CONFIG_PTP_CUSTOM
@itemx CONFIG_PTP_REMOTE_CONF

	By default (@t{CONFIG_PTP_PORT_PARAMS}), PTP daemon (PPSi) configuration file
  is generated based on the values stored in @t{CONFIG_PORT@i{xx}_@i{zz}}
  parameters. 
  If VLANs are configured, the items @t{CONFIG_VLANS_PORT@i{xx}_VID} are used as well.
  Any additional, global PPSi settings can be added by editing manually the
  @t{/wr/etc/ppsi-pre.conf} file, which is then used as the base for the final
  PPSi configuration file.
	Alternatively, PPSi can use a fully custom, user-defined file for
  configuration (@t{CONFIG_PTP_CUSTOM}).

	Finally, you can choose @t{PTP_REMOTE_CONF} to
        specify an URL whence the switch will download the @t{ppsi.conf} at
        boot time.

        Please see the help provided within @i{Kconfig} for more details about
        the various supported options.
	

@item CONFIG_PTP_CUSTOM_FILENAME
	If you chose @t{CONFIG_PTP_CUSTOM} from the options described above, you
  can provide your own filename for the PPSi configuration file.
  The introduced filename is expected to be installed in the @sc{wrs}
  filesystem.
@item CONFIG_PTP_CONF_URL

	If you choose @t{CONFIG_PTP_REMOTE_CONF} specify an URL
	(@t{http://}, @t{ftp://} or @t{tftp://}) whence
        the switch will download the @t{ppsi.conf} at boot time.
        The filename in the URL can include @t{HOSTNAME}, @t{IPADDR}
        and/or @t{MACADDR}, so the same configuration string can be used to set
        up a batch of switches with different configurations (similar to the
        @t{CONFIG_DOTCONF_URL}, please refer to @ref{The Configuration File}).

@item CONFIG_PPSGEN_PTP_FALLBACK
@itemx CONFIG_PPSGEN_PTP_THRESHOLD_MS
@itemx CONFIG_PPSGEN_GM_DELAY_TO_GEN_PPS_SEC
@itemx CONFIG_PPSGEN_FORCE
@itemx CONFIG_PPSGEN_FR_ON_SYNC_ONLY
	Configuration of the 1-PPS (Pulse Per Second) output.
  The generation of 1-PPS output heavily depends on the configured timing mode:
  @itemize
    @item GrandMaster (@t{CONFIG_TIME_GM}, PTP clock class 6)
      PPS generation is always enabled.
    @item Free-running Master (@t{CONFIG_TIME_FM}, PTP clock class 193)
      PPS generation is by default always enabled.
      If @t{CONFIG_PPSGEN_FR_ON_SYNC_ONLY} is set, then PPS is generated only
      when a switch becomes slave and synchronize to another master.
    @item Arbitrary GrandMaster (@t{CONFIG_TIME_ARB_GM}, PTP clock class 13)
      PPS generation is disabled unless @t{CONFIG_PPSGEN_FORCE} is set
    @item Boundary Clock (@t{CONFIG_TIME_BC}, PTP clock class 248)
      PPS is generated only when the device is synchronized. If @t{CONFIG_PPSGEN_FORCE}
      is set, PPS is generated at all times.
    @item Custom mode (@t{CONFIG_TIME_CUSTOM})
      PPS generation depends on configured PTP clock class, e.g. if PTP clock class
      is set to 6, PPS generation scheme will be the one of the GrandMaster
      listed above. If @t{CONFIG_PPSGEN_FORCE} is set, PPS is generated at all times.
  @end itemize

  Additionally to the conditions listed above, if PTP Best Master Clock Algorithm (BMCA) is enabled
  some spurious PPS can be generated during the transitory phase e.g. when the network hierarchy is
  being established (during startup or re-organization). To suppress those @t{CONFIG_PPSGEN_GM_DELAY_TO_GEN_PPS_SEC} defines a delay time
  in seconds from the moment @sc{wrs} became a PTP grandmaster to the moment PPS starts to be generated.
  By default this parameter is set to 60s.
  
	The @t{CONFIG_PPSGEN_PTP_THRESHOLD_MS} option is applied when @sc{wrs} is synchronized to a regular
  (non-@sc{wr}) PTP master. This threshold defines a maximum offset to master
  (in milliseconds) when the @sc{wrs} is considered synchronized.
  Once the calculated offset falls
  below the configured threshold, PPS generation starts. To disable PPS, PTP offset must be
  greater than the @t{CONFIG_PPSGEN_PTP_THRESHOLD_MS} + 20%.
	Setting this parameter to 0 will block any PPS generation for those cases. 
	The @t{CONFIG_PPSGEN_PTP_FALLBACK} option, if activated, enables the PPS generation
  when a slave instance programmed to use an extension protocol (WR, L1Sync, ...)
  is falling back to regular PTP synchronization. 

@item CONFIG_RVLAN_ENABLE
@itemx CONFIG_RVLAN_PMASK
@itemx CONFIG_RVLAN_AUTH_VLAN
@itemx CONFIG_RVLAN_NOAUTH_VLAN
@itemx CONFIG_RVLAN_OBEY_DOTCONFIG
@itemx CONFIG_RVLAN_RADIUS_SERVERS
@itemx CONFIG_RVLAN_RADIUS_SECRET
	Configuration items related to @i{radiusvlans}, which can be used to
	limit access to WR network for connected devices based on MAC address.
	For more details please refer to @i{White Rabbit Switch: Radius Vlan}.

@item CONFIG_SNMP_TRAPSINK_ADDRESS
@itemx CONFIG_SNMP_TRAP2SINK_ADDRESS
@itemx CONFIG_SNMP_RO_COMMUNITY
@itemx CONFIG_SNMP_RW_COMMUNITY

	Configuration for the @sc{snmp} agent. Addresses can be IP addresses
        or names (if DNS is configured and working), they are unset by
        default. Community values are strings and they default to
        @t{public} (@t{RO_COMMUNITY}) and @t{private} (@t{RW_COMMUNITY}).

@item CONFIG_SNMP_TEMP_THOLD_FPGA
@itemx CONFIG_SNMP_TEMP_THOLD_PLL
@itemx CONFIG_SNMP_TEMP_THOLD_PSL
@itemx CONFIG_SNMP_TEMP_THOLD_PSR
	Threshold levels for FPGA, PLL, Power Supply Left (PSL) and Power
        Supply Right (PSR) temperature sensors. When any temperature exceeds
        threshold level, SNMP object @t{WR-SWITCH-MIB::tempWarning} will change
@item CONFIG_SNMP_SWCORESTATUS_DISABLE
	Force SNMP object @t{wrsSwcoreStatus} to be always OK. It can be used
	to ignore all Ethernet frames switching related issues.
@c @item CONFIG_SNMP_SWCORESTATUS_HP_FRAME_RATE
@c
@c	Error via SNMP if the rate of HP frames on any port exceed given value.
@c	(currently not implemented)
@c@item CONFIG_SNMP_SWCORESTATUS_RX_FRAME_RATE
@c
@c	Error via SNMP if rate of RX frames on any port exceed given value.
@c	(currently not implemented)
@c@item CONFIG_SNMP_SWCORESTATUS_RX_PRIO_FRAME_RATE
@c
@c	Error if frame rate of any RX priority exceed given value.
@c	(currently not implemented)
@item CONFIG_SNMP_SYSCONTACT
	Free text intended to be the textual identification of the contact
	person for this switch, together with information on how to contact this
	person. Reported by SNMP as SNMPv2-MIB::sysContact.0

@item CONFIG_SNMP_SYSLOCATION
	Free text intended to be The physical location of this node.
	Reported by SNMP as SNMPv2-MIB::sysLocation.0

@item CONFIG_SNMP_SYSTEM_CLOCK_MONITOR_ENABLED
@itemx CONFIG_SNMP_SYSTEM_CLOCK_DRIFT_THOLD
@itemx CONFIG_SNMP_SYSTEM_CLOCK_UNIT_DAYS
@itemx CONFIG_SNMP_SYSTEM_CLOCK_UNIT_HOURS
@itemx CONFIG_SNMP_SYSTEM_CLOCK_UNIT_MINUTES
@itemx CONFIG_SNMP_SYSTEM_CLOCK_CHECK_INTERVAL_DAYS
@itemx CONFIG_SNMP_SYSTEM_CLOCK_CHECK_INTERVAL_HOURS
@itemx CONFIG_SNMP_SYSTEM_CLOCK_CHECK_INTERVAL_MINUTES

	When @t{CONFIG_SNMP_SYSTEM_CLOCK_MONITOR_ENABLED} option is set, 
  the local system time is compared to the time 
  acquired from the external NTP server (according to @t{CONFIG_NTP_SERVER}).
  If the difference of time exceeds a given threshold
  (defined by @t{CONFIG_SNMP_SYSTEM_CLOCK_DRIFT_THOLD})
  expressed in seconds, an error is reported through SNMP.
	This comparison is done periodically at a rate expressed either in days 
	(@t{CONFIG_SNMP_SYSTEM_CLOCK_UNIT_DAYS}), hours (@t{CONFIG_SNMP_SYSTEM_CLOCK_UNIT_HOURS}) or
	minutes (@t{CONFIG_SNMP_SYSTEM_CLOCK_UNIT_MINUTES}).
	
	According to the selected unit, the repetition rate will be stored in the appropriate location:  
	@multitable @columnfractions .3 .7
	@headitem  Unit @tab Storage 
	@item  @t{...UNIT_DAYS} @tab @t{...CHECK_INTERVAL_DAYS}
	@item  @t{...UNIT_HOURS} @tab @t{...CHECK_INTERVAL_MINUTES}
	@item  @t{...UNIT_MINUTES} @tab @t{...CHECK_INTERVAL_MINUTES}
	@end multitable
	
	The @t{CONFIG_SNMP_SYSTEM_CLOCK_MONITOR_ENABLED} option is available only if a
	NTP server has been defined (@t{CONFIG_NTP_SERVER}).

@item CONFIG_WRSAUXCLK_FREQ
@itemx CONFIG_WRSAUXCLK_DUTY
@itemx CONFIG_WRSAUXCLK_CSHIFT
@itemx CONFIG_WRSAUXCLK_SIGDEL
@itemx CONFIG_WRSAUXCLK_PPSHIFT

  Configuration parameters to generate WR-synchronized 10MHz clock on the
  @i{clk2} output of the @sc{wrs} front panel. All these parameters are directly
  passed to @t{wrs_auxclk} tool of @sc{wrs}.
  In case you need to generate another clock frequency, please refer to
  @ref{wrs_auxclk}.
@item CONFIG_EXT_PPS_LATENCY_PS
	A value in ps to align the 1-PPS input and 1-PPS output.

@item CONFIG_NIC_THROTTLING_ENABLED
@itemx CONFIG_NIC_THROTTLING_VAL

	Limit the Rx bandwidth of the traffic that goes from WR ports to Linux.
	Throttling can be enabled to prevent Linux using 100% of the processing
	power to receive Ethernet frames coming from WR ports to the CPU.
	To enable the throttling set @t{CONFIG_NIC_THROTTLING_ENABLED}.
	@t{CONFIG_NIC_THROTTLING_VAL} contains maximum allowed bandwidth
	in KB/s.

@item CONFIG_PPS_IN_TERM_50OHM
	Enable 50ohm termination for 1-PPS input.

@item CONFIG_CUSTOM_BOOT_SCRIPT_ENABLED
@itemx CONFIG_CUSTOM_BOOT_SCRIPT_SOURCE_LOCAL
@itemx CONFIG_CUSTOM_BOOT_SCRIPT_SOURCE_REMOTE
@itemx CONFIG_CUSTOM_BOOT_SCRIPT_SOURCE_REMOTE_URL

	It is possible to run a custom script at boot time. In this case please
        set @t{CONFIG_CUSTOM_BOOT_SCRIPT_ENABLED}.
        To run a script @t{/wr/bin/custom_boot_script.sh} from the local
        filesystem please set @t{CONFIG_CUSTOM_BOOT_SCRIPT_SOURCE_LOCAL}.
	As an alternative, you can choose
        @t{CONFIG_CUSTOM_BOOT_SCRIPT_SOURCE_REMOTE} and specify an URL
        (@t{http://}, @t{ftp://} or @t{tftp://}) in
        @t{CONFIG_CUSTOM_BOOT_SCRIPT_SOURCE_REMOTE_URL} whence
        the switch will download the script to be executed at boot time.
        The filename in the URL can include @t{HOSTNAME}, @t{IPADDR}
        and/or @t{MACADDR}, so the same configuration string can be used to set
        up a batch of switches with different configurations (similar to the
        @t{CONFIG_DOTCONF_URL}, please refer to @ref{The Configuration File}).
@item CONFIG_LLDPD_DISABLE
@itemx CONFIG_LLDPD_TX_INTERVAL
@itemx CONFIG_LLDPD_MANAGEMENT_PORT_DISABLE
@itemx CONFIG_LLDPD_MINIMUM_FRAME_SIZE

	Set of parameters related to the LLDP daemon (lldpd) configuration.
	Starting from version 6.0, switch by default sends LLDP frames on all
	ports (including management). In some installations it may be necessary
	to disable LLDP traffic on the management port (option
	@t{CONFIG_LLDPD_MANAGEMENT_PORT_DISABLE}). Additionally, in some cases
	(e.g. low latency networks) it may be necessary to disable
	LLDP at all (@t{CONFIG_LLDPD_DISABLE}).

	The transmission frequency of LLDP frames can be changed using option
	@t{CONFIG_LLDPD_TX_INTERVAL}.

	Networks that would benefit from the LLDP, but have low latency
	constraints can use option @t{CONFIG_LLDPD_MINIMUM_FRAME_SIZE}. With
	this option LLDP daemon includes only minimal set of information into
	LLDP frames.
	The table below contains comparison of LLDP frame fields for standard
	and minimal frame size (with
	@t{CONFIG_LLDPD_MINIMUM_FRAME_SIZE} option enabled). Size of some of
	those fields (like @t{System name} or	@t{System Description}) depends on
	the network configuration.

@multitable @columnfractions .25 .25 .35
@headitem Standard frame @tab Minimum frame @tab Description
@item 14
@tab 14
@tab ETH header
@item 9
@tab 9
@tab Chassis ID (with MAC)
@item 9
@tab 9
@tab Port ID (with MAC)
@item 4
@tab 4
@tab Time To Live
@item 2+len(System name)
@tab 2+len(System name)
@tab System name
@item 2+len(System desc.)
@tab 2+len(@t{WR-SWITCH})
@tab System description
@item 6
@tab 0
@tab Capabilities
@item 14
@tab 0
@tab Management Address
@item 7
@tab 7
@tab Port description
@item 2
@tab 2
@tab End of LLDP frame

@item 69

+len(System name)

+len(System desc.)
@tab 58

+len(System name)
@tab Total length

@end multitable
@item CONFIG_HTTPD_DISABLE
	Disable web interface on a switch.
	Web interface is now disabled by default and considered deprecated.
	A number of security vulnerabilities were found in the web interface
	(including CVE-2023-22577).
	Please note that it is still possible to enable web interface in
	run-time.
	@b{Users are strongly discouraged from using the web interface}.
	In exceptional cases the use of web-interface can be limited to well
	controlled networks.
	Disable monitoring of running processes by @i{Monit}. @i{Monit} by
        default
        re-spawns processes that have died. This option should be used only during
@item CONFIG_FAN_HYSTERESIS
@itemx CONFIG_FAN_HYSTERESIS_T_DISABLE
@itemx CONFIG_FAN_HYSTERESIS_T_ENABLE
@itemx CONFIG_FAN_HYSTERESIS_PWM_VAL

	Use hysteresis to control fans. Enable fans with PWM value
	@t{CONFIG_FAN_HYSTERESIS_PWM_VAL} when PLL's temperature exceeds
	@t{CONFIG_FAN_HYSTERESIS_T_ENABLE}. Disable fans when temperature drops
	below @t{CONFIG_FAN_HYSTERESIS_T_DISABLE}. These options are intended to
	be used during development to reduce noise generated by a switch.
	Don't use in production as this may affect the synchronization
	performance.
	Enable readout of additional monitoring information (DOM) like temperature,
  Tx/Rx power, from SFP transceivers. Please note that not all Gigabit Ethernet
  SFP transceivers provide the DOM structure.
@item CONFIG_OPTIMIZATION_DEBUGGING
@itemx CONFIG_OPTIMIZATION_NONE_DEBUGGING
@itemx CONFIG_OPTIMIZATION_SIZE_SPEED
@itemx CONFIG_OPTIMIZATION_SPEED
	
	Compilation options. Chose one of these four choices to control the 
	compilation flags.
	
	@t{CONFIG_OPTIMIZATION_DEBUGGING}: Should be the optimization level choice 
	  for the standard edit-compile-debug cycle.
	
	@t{CONFIG_OPTIMIZATION_NONE_DEBUGGING}: Compile without optimization and with debug information
	
	@t{CONFIG_OPTIMIZATION_SIZE_SPEED}: Optimize for size. Enables all -O2 optimizations except those 
	  that often increase the code size.
	
	@t{CONFIG_OPTIMIZATION_SPEED}: GCC performs nearly all supported optimizations 
	  that do not involve a space-speed trade-off.
	 
@item CONFIG_RTU_HP_MASK_ENABLE
@itemx CONFIG_RTU_HP_MASK_VAL

	Set the mask which VLAN priorities are considered High Priority traffic
	(this
	only concerns the traffic which is fast-forwarded).
	To enable a custom mask please set
	@t{CONFIG_RTU_HP_MASK_ENABLE}.
	@t{CONFIG_RTU_HP_MASK_VAL} shall contain the mask to be used.
@item CONFIG_VLANS_ENABLE

	Enable VLANs configuration. All below VLAN config options
	(@t{CONFIG_VLANS_*}) require this filed to be set.

@item CONFIG_VLANS_PORT@i{xx}_MODE_ACCESS
@itemx CONFIG_VLANS_PORT@i{xx}_MODE_TRUNK
@itemx CONFIG_VLANS_PORT@i{xx}_MODE_DISABLED
@itemx CONFIG_VLANS_PORT@i{xx}_MODE_UNQUALIFIED
	VLANs port mode configuration for ports 1..18.
	It can be one of: Access, Trunk, Disabled or Unqualified.
	For details please refer to the @ref{VLANs Configuration}

@item CONFIG_VLANS_PORT@i{xx}_UNTAG_ALL
@itemx CONFIG_VLANS_PORT@i{xx}_UNTAG_NONE
	Define whether to remove a VLAN tag from egress frames on port 1..18.
@item CONFIG_VLANS_PORT@i{xx}_PRIO
	Priority value used when tagging incoming frames or to locally override
	the priority (in Unqualified and Disabled modes).
	-1 disables the priority overwrite. Valid values are
@item CONFIG_VLANS_PORT@i{xx}_VID
  Define the  VID tagging incoming frames and notify PPSi which 
  VLAN shall be used for synchronization; only one VLAN number 
  shall be used.
  This parameter is available for @t{MODE_ACCESS} mode.
	The range of a valid VID is from 0 to 4094.
 	For details please refer to the @ref{VLANs Configuration}

@item CONFIG_VLANS_PORT@i{xx}_PTP_VID

  Notify PPSi which VLAN(s) shall it use for synchronization; semicolon separated list is allowed.
  This parameter is available for @t{MODE_TRUNK}, @t{MODE_DISABLED} and
  @t{MODE_UNQUALIFIED} modes. 
  The range of a valid VID is from 0 to 4094.
	For details please refer to the @ref{VLANs Configuration}
@item CONFIG_VLANS_PORT@i{xx}_LLDP_TX_VID
@itemx CONFIG_VLANS_PORT@i{xx}_LLDP_TX_PRIO

  Notify lldpd which VLAN shall it use for sending LLDP frames.
  Incoming LLDP frames are accepted on all VLANs.
  This parameter is available for @t{MODE_TRUNK}, @t{MODE_DISABLED} and
  @t{MODE_UNQUALIFIED} modes. 
  The range of a valid VID is from 0 to 4094.
  @t{VLANS_PORTxx_LLDP_TX_PRIO} defines the priority to be inserted into
  a VLAN tag of LLDP frames sent by lldpd.

@item CONFIG_VLANS_RAW_PORT_CONFIG

  Expert mode. Allow to control all VLAN parameters (CONFIG_VLANS_PORT@i{xx}_PTP_VID,
  CONFIG_VLANS_PORT@i{xx}_VID, CONFIG_VLANS_PORT@i{xx}_MODE_@i{yy} and
  CONFIG_VLANS_PORT@i{xx}_UNTAG_@i{xx} ) without any restrictions. 
  The user must be aware of what it is doing.
  
@item CONFIG_VLANS_VLAN@i{xxxx}
	Provide a configuration for VLAN from the range 0000-4094.
	This option is a comma separated string in the following format:

	@t{fid=<0..4094>,prio=<-1|0..7>,drop=<y|n>,ports=<1;2;...;...-...;18>}
	@item @t{fid} is a associated Filtering ID (FID) number. This parameter
	  may be useful for complex VLAN configurations. In simple cases it can
	  be omitted. One FID can be
	  associated with many VIDs. RTU learning is performed per-FID.
	  Associating many VIDs with a single FID allowed shared-VLANs
	  learning.
	@item @t{prio} is a priority of a VLAN; can take values between -1 and
	  7;
	  -1 disables priority override, any other valid number takes
	  precedence over the port priority
	@item If @t{drop} is set to @t{y}, @t{yes} or @t{1}, all frames
	  belonging to this VID are dropped (note that frame can belong to a
	  VID as a consequence of per-port Endpoint configuration); can take
	  values @t{y}, @t{yes}, @t{1}, @t{n}, @t{no}, @t{0}
	@item @t{ports} is a list of ports separated with a semicolon sign
	  (";"); ports ranges are supported (with a dash character)
	@t{fid=4,prio=2,drop=n,ports=1;3-5;15}
	It sets FID as 4, priority 2, don't drop frames belonging to this VLAN,
	For more details about VLANs configuration please refer to the
	@ref{VLANs Configuration}
@c ==========================================================================
@node Timing Configuration
@section Timing Configuration

This section describes how timing configuration works in the switch.
Please note that, comparing to previous firmware releases, the timing configuration
has considerably evolved in version @value{release_version}.
 
Timing configuration now depends on four sets of @t{dot-config}
variables: common port information, per-port information, sfp information and fiber
description.

This is, for explanation's sake, an example of such items:

@smallexample
# common port information
PTP_OPT_EXT_PORT_CONFIG_ENABLED=yes
...
# per-port information
CONFIG_PORT09_IFACE="wri9"
CONFIG_PORT09_FIBER=2
CONFIG_PORT09_INSTANCE_COUNT_1=yes
CONFIG_PORT09_INST01_PROTOCOL_RAW=yes
CONFIG_PORT09_INST01_PROFILE_WR=yes
CONFIG_PORT09_INST01_DESIRADE_STATE_SLAVE=yes
CONFIG_PORT09_INST01_EGRESS_LATENCY=226214
CONFIG_PORT09_INST01_INGRESS_LATENCY=226758
...
# sfp information
CONFIG_SFP00_PARAMS="pn=AXGE-1254-0531,tx=0,rx=0,wl_txrx=1310+1490"
# fiber information
CONFIG_FIBER02_PARAMS="alpha_1310_1490=2.6787e-04"
@end smallexample

When making timing calculation for port @t{wri9}, assuming the
auto-detected @sc{sfp} model is``AXGE-1254-0531'', the software
uses configuration in the following way:

@itemize @bullet

@item The port has known tx (@t{CONFIG_PORT09_INST01_EGRESS_LATENCY}) and 
rx (@t{CONFIG_PORT09_INST01_INGRESS_LATENCY}) delays (around 226ns); the
values depend on trace length and other hardware-specific details
and are determined by the @sc{wr}  calibration procedure.  These values are
used by the @sc{WR} PTP daemon for accurate estimation of the transmission
link asymmetry.

@item The port is configured as WR slave (@t{CONFIG_PORT09_INST01_DESIRADE_STATE_SLAVE}) 
using raw Ethernet (@t{CONFIG_PORT09_INST01_PROTOCOL_RAW}) to synchronize using the
White-Rabbit protocol (@t{CONFIG_PORT09_INST01_PROFILE_WR}) and is deployed using
fiber type 2 (@t{CONFIG_PORT09_FIBER}) -- this number
is just a local enumeration of fiber types corresponding to an entry in
the @i{fiber information} section of the configuration. Most typical @sc{wr}
installations use a single type of fiber, indexed as "0" for every port.

@item The SFP transceiver used in this example emits 1310nm light for tx
and receives 1490nm light (this is part of the specification of the
transceiver, and cannot be auto-detected). Moreover, it has 0 constant
delay in both directions (tx/rx), determined by the @sc{wr} calibration
procedure.

@item The relative asymmetry of the fiber type being used (type 2 here), when
driven with 1310nm and 1490nm wavelengths, is characterized with an @i{alpha}
parameter of 0.00026787 (i.e. a ratio of 1.00026787). This value depends on
both, the fiber type and the wavelength used, and is determined, again,
by the @sc{wr} calibration procedure.
Please note that only one alpha value has to be provided for each fiber type.
The @i{alpha} in the opposite direction (@t{alpha_1490_1310}) is calculated
by the software.
@subsection Common port configuration
The following table lists the configuration items that are common to all port
instances of the WR switch.

@table @code

@item CONFIG_PTP_OPT_EXT_PORT_CONFIG_ENABLED

	  This option enables forcing the PTP state for each port instance using
    @t{CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_*} parameters. 
	  When set, each port instance can be forces to always stay either in the
    slave, master or passive state.
	  The PTP Best Master Clock Algorithm (BMCA) is then disabled.
	  This option is only available for a boundary clock (@t{CONFIG_TIME_BC}).
	  For more details please refer to the IEEE 1588-2020 (clause 17.6.2)
	  
@item CONFIG_PTP_SLAVE_ONLY

	  A slaveOnly Ordinary Clock utilizes the slaveOnly state machine
	  which does not enable transition to MASTER state.
	  This option is only available if @t{PTP_OPT_EXT_PORT_CONFIG_ENABLED}
	  is not used.
	  For more details please refer to the IEEE 1588-2020 (clause 9.2.2.1)
	
@end table

@subsection  Per-port configuration
@table @code
@item @t{CONFIG_PORT@i{xx}_INSTANCE_COUNT_1}
@item @t{CONFIG_PORT@i{xx}_INSTANCE_COUNT_0}

  Each physical @sc{wrs} port can be configured to run several PPSi instances.
  However, only one instance per-port can be active at any given moment. This functionality
  is required to support several PTP extensions (e.g. @sc{wr}, @sc{HA} - High Accuracy
  profile). The active instance will dependent then of the profile used by the peer on
  the other side of the link.

  WR switch firmware version @value{release_version} implements only a single,
  @sc{WR} extension, therefore the possibility of running several instances on a single
  port is disabled. The number of port instances must be set to either 1
  (@t{CONFIG_PORT@i{xx}_INSTANCE_COUNT_1=yes}) or 0 (@t{CONFIG_PORT@i{xx}_INSTANCE_COUNT_0=yes})
  if the port is not used. @i{xx} represents the port number in the range 01 to 18. 

@end table
@subheading  Common instance configuration
A set of parameters common to all instances running on the same physical port. The 
@i{xx} value in the parameter name represents the port number.

@table @code

@item  CONFIG_PORT@i{xx}_IFACE
	 Used to define the physical port interface name: "wri[1-18]"
	 
@item  CONFIG_PORT@i{xx}_FIBER
	Identify the fiber type. This is a number (@i{zz}) referring to the corresponding 
	@t{CONFIG_FIBER@i{zz}_PARAMS})
	
@item  CONFIG_PORT@i{xx}_CONSTANT_ASYMMETRY
	Defines an additional constant asymmetry (e.g. of a fiber amplifier used
	in long-haul @sc{wr} networks) that should be compensated by @sc{wr}
	PTP calculations.

@end table
  
@subheading  Instance information description

All port instance parameters shared the following naming scheme:
CONFIG_PORT@i{xx}_INST@i{yy}_@i{pp}, where @i{xx} represents the port number,
@i{yy} the instance number (01 to 02) and @i{pp} a key describing the
parameter itself. 

@table @code

@item  CONFIG_PORT@i{xx}_INST@i{yy}_PROTOCOL_RAW
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_PROTOCOL_UDP_IPV4
  Network transport layer selection, either raw Ethernet or UDP over IPv4 can be used.
 
@item  CONFIG_PORT@i{xx}_INST@i{yy}_PROFILE_WR
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_PROFILE_PTP
  Profile selection. @t{CONFIG_PORT@i{xx}_INST@i{yy}_PROFILE_WR} must be set to use the White Rabbit profile and 
  @t{CONFIG_PORT@i{xx}_INST@i{yy}_PROFILE_PTP} for pure PTP profile.
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_MECHANISM_E2E
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_MECHANISM_P2P
  PTP delay mechanism, either 'end-to-end' (E2E) or 'peer-to-peer' (P2P) can be used.
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_MASTER
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_SLAVE
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_PASSIVE
  If @t{CONFIG_PTP_OPT_EXT_PORT_CONFIG_ENABLED} is enabled then the desired PTP state
  of the instance must be defined as follows:
  @multitable @columnfractions .2 .8 
  @headitem State @tab Parameter
  @item MASTER  @tab @t{CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_MASTER}
  @item SLAVE   @tab @t{CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_SLAVE}
  @item PASSIVE @tab @t{CONFIG_PORT@i{xx}_INST@i{yy}_DESIRADE_STATE_PASSIVE}
  @end multitable
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_ASYMMETRY_CORRECTION_ENABLE
  This option is only accessible when the PTP profile is selected otherwise this option is enabled by default. 
  It is used to force the servo to integrate on its calculation the computation of the delay asymmetry. 
  
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_BMODE_AUTO
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_BMODE_MASTER_ONLY
  Indicates the BMCA mode to be used. The choice is available only when
  @t{CONFIG_PTP_OPT_EXT_PORT_CONFIG_ENABLED} is disabled. Either the regular PTP BMCA
  (@t{BMODE_AUTO}) or PTP masterOnly feature (@t{BMODE_MASTER_ONLY})
  can be used.
  For more details please refer to the IEEE 1588-2020 (clause 9.2.2.2)
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_EGRESS_LATENCY
@itemx  CONFIG_PORT@i{xx}_INST@i{yy}_INGRESS_LATENCY
  Defines the reception (@t{CONFIG_PORT@i{xx}_INST@i{yy}_INGRESS_LATENCY}) and transmission 
  (@t{CONFIG_PORT@i{xx}_INST@i{yy}_EGRESS_LATENCY}) constant delays expressed in
  picoseconds.
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_ANNOUNCE_INTERVAL
  The mean time interval between transmissions of successive
	PTP Announce messages. The value expressed as base 2 logarithm.
  
@item  CONFIG_PORT@i{xx}_INST@i{yy}_ANNOUNCE_RECEIPT_TIMEOUT
  The number of announceIntervals that must pass without receipt of an Announce
  message before the occurrence of the PTP event ANNOUNCE_RECEIPT_TIMEOUT_EXPIRES.
	The value expressed as base 2 logarithm. For more details please refer to
  IEEE 1588-2020 standard.
    
@item  CONFIG_PORT@i{xx}_INST@i{yy}_SYNC_INTERVAL
	  The mean time interval between transmission of successive
	  PTP Sync messages, i.e., the sync-interval, when transmitted
	  as multicast messages. The value expressed as base 2 logarithm.

@item  CONFIG_PORT@i{xx}_INST@i{yy}_MIN_DELAY_REQ_INTERVAL
	  The minDelayRequestInterval specifies the minimum permitted
	  mean time interval between successive Delay_Req messages.
    The value expressed as base 2 logarithm.
    This option is available when 'end-to-end' delay mechanism is selected 
    (@t{CONFIG_PORT@i{xx}_INST@i{yy}_MECHANISM_E2E}).

@item  CONFIG_PORT@i{xx}_INST@i{yy}_MIN_PDELAY_REQ_INTERVAL
	  The minPDelayRequestInterval specifies the minimum permitted
	  mean time interval between successive Pdelay_Req messages.
    The value expressed as base 2 logarithm.
    This option is only available when 'peer-to-peer' delay mechanism is selected
    (@t{CONFIG_PORT@i{xx}_INST@i{yy}_MECHANISM_P2P}).

@item  CONFIG_PORT@i{xx}_INST@i{yy}_MONITOR
  Option to decide whether timing-related errors for a given port will be reported
  through SNMP.

@c  --------------------------
@c Option that will be available whe HA will be deployed
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_ENABLED
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_INTERVAL
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_RECEIPT_TIMEOUT
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_TX_COHERENCY_IS_REQUIRED
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_RX_COHERENCY_IS_REQUIRED
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_CONGRUENCY_IS_REQUIRED
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_OPT_PARAMS_ENABLED
@c @item  CONFIG_PORT@i{xx}_INST@i{yy}_L1SYNC_OPT_PARAMS_TS_CORRECTED_TX_ENABLED


@end table

@subsection SFP name matching
Each time you plug an SFP transceiver into any of the @sc{wrs} ports, it has to be matched
against @t{dot-config} entries specifying the timing parameters and wavelength for the
supported transceivers.
The matching algorithm reads from the SFP its vendor name (@i{vn}), part number (@i{pn}), vendor
serial (@i{vs}) and TX wavelength in @t{nm}. Note that it only reads the integer part (i.e. rounded down)
of the TX wavelength, as shown by @t{wrs_sfp_dump}. Then, these SFP parameters are compared
 with the values stored in the @t{CONFIG_SFP@i{xx}_PARAMS} @t{dot-config} entries:
@item
  The @i{wl_txrx} field in the @t{CONFIG_SFP@i{xx}_PARAMS} must contain the transmit and receive
  wavelengths of the SFP in @t{nm}, as integers, separated by a '+'. The TX wavelength as
  reported by the SFP is matched against the tx entry (first number) in the @i{wl_txrx} entry. If these do
  not match, then this @t{CONFIG_SFP@i{xx}_PARAMS} entry cannot match against this SFP.
  For the remaining parameters, first a match against all the vendor SFP identifiers
  (@i{vn}, @i{pn} and @i{vs}) is attempted.
@item
  If a corresponding entry cannot be found, the match is limited to @i{vn} and @i{pn} and
  compared only with those @t{dot-config} entries that do not specify any vendor serial.
@item
  If the match still cannot be found, it is limited again, to @i{pn} only.

@end itemize

To understand better the operation of SFP matching algorithm, please see below some examples:
@itemize @bullet
@item
  @t{CONFIG_SFP00_PARAMS="vn=Axcen Photonics,pn=AXGE-3454-0531,vs=AX12390009629,
  tx=0,rx=0,wl_txrx=1490+1310"}

  This entry can be matched only to one SFP transceiver as it specifies full set of parameters,
  including the unique vendor serial number (@i{vs}).

@item
  @t{CONFIG_SFP01_PARAMS="vn=Axcen Photonics,pn=AXGE-3454-0531,tx=0,rx=0,
  This entry may be matched only to all SFPs with vendor name "Axcen Photonics",
  part number "AXGE-3454-0531" and a TX wavelength of 1490 nm, with exception of the SFP
  that was already matched to
  the previous entry @t{CONFIG_SFP00_PARAMS} (with vendor serial defined).

@item
  @t{CONFIG_SFP02_PARAMS="pn=AXGE-1254-0531,tx=0,rx=0,wl_txrx=1310+1490"}
  This entry will be matched to all SFPs with part number "AXGE-3454-0531" and TX wavelength of
  1310 nm, that were not matched by any of the entries listed earlier.
@subsection Other Deployments
All examples from previous sections match typical @sc{wr} networks we setup at
CERN with a single mono-modal fiber and 1310/1490 nm light wavelengths.

If you are using dual-fiber transceivers, which is acceptable for
short links, you use the same wavelength in both directions, over two
fibers of the same length. In this case you may omit the 
@t{wl_txrx} parameter in @sc{sfp} @t{dot-config} configuration and the
@t{alpha_@i{xx}_@i{xx}} parameter in fiber configuration.  The missing
parameters will cause warning messages to log destination, but are not
fatal, and a default alpha of 0 is used.

If you are using a pair of transceivers with different wavelengths,
and long fibers, you should provide an appropriate value of alpha,
according to laboratory measures of your fiber type. The
@t{CONFIG_FIBER@i{xx}_PARAMS} items are parsed as a list of
comma-separated assignments, so you can specify multiple
wavelength pairs. Each entry has the form @t{alpha_1310_1490=2.6787e-4}, where the numbers
are again the wavelength in integer @t{nm}. Note that only one value of alpha is needed for
each pair of wavelengths, the switch will calculate the correct value of alpha when the wavelengths
are switched around.

Example: @t{CONFIG_FIBER00_PARAMS="alpha_1310_1490=2.6787e-04"}

The accuracy of your value depends on the length
of the fiber link.  For a 10km fiber (100us round-trip) you need to know
alpha up to 1e-7 if you want the related uncertainty to be
less than 10ps.

@subsection Calibration
Calibration of per-port and per-@sc{sfp} delays as well as alpha is described in the
White Rabbit Calibration procedure:
@url{http://www.ohwr.org/projects/white-rabbit/wiki/Calibration}.

The delays used in the examples come from values listed in the calibration wiki
page, and you should not be surprised by the fact that the
transceiver (SFP) specifies the delays as zero.  By performing the
calibration procedure using this very transceiver type, the whole delay is
assigned to the port.  Other transceiver
types can be calibrated to either positive or negative values, to cope
with the @i{difference} between them and the default @t{AXGE} devices.
@c ==========================================================================
@node VLANs Configuration
@section VLANs Configuration

VLANs are handled at two levels:

@itemize
    @item Per-port configuration of the Endpoint. It allows to:
    @itemize
	@item tag ingress frames with VLAN-tag and specific priority
	@item specify behavior depending on whether the frames are tagged or
	      untagged (@t{pmode})
@c 	@item map priorities into @i{Traffic Class} that are provided to RTU
	@item override priority before it is mapped into @i{Traffic Class},
	      i.e. translate into @i{Traffic Class} different priority than
	      the one received in the VLAN-tag
	@item remove VLAN-tag of given VID(s) from egress frames
	@item override VID in the VLAN-tag of a priority-tagged frame (VID=0x0)
    @end itemize

    @item Per-VID by configuring the RTU. It allows to:
    @itemize
	@item limit the ports to which frames with a given VID are forwarded
%	@item limit the ports from which frames with given VID are accepted
%	      @footnote{Should, but does not now. There is a bug in HDL.}
	@item override priority (@i{Traffic Class}) for a given VID
	@item drop frames with a given VID
    @end itemize

@end itemize
In terms of VLAN-tag, there are four types of VLAN-tags that can extend
the Ethernet Frame header:
@itemize
    @item @i{none}     -- tag is not included in the Ethernet Frame
    @item @i{priority} -- tag that has VID=@t{0x0}
    @item @i{VLAN}     -- tag that has VID in the range @t{0x001} to @t{0xFFE}
                          (1 to 4094)
    @item @i{null}     -- tag that has VID=@t{0xFFF} (4095)
The behavior of each @t{pmode} that can be set per-port depends on the type of
VLAN-tag in the received frame.

@itemize
    @item Mode @t{ACCESS} (0x0), frames with:
    @itemize
	@item @i{no VLAN-tag}: are admitted, tagged with the values of VID and
			priority that are configured in @t{pvid} and @t{pprio}
			respectively
	@item @i{priority tag}: are admitted, the value of VID in their VLAN-tag is
                        overridden with the value configured in n @t{pvid}. This
                        new value of VID is provided to the RTU. If @t{pprio} is
                        not -1, the value of priority provided to RTU is
                        overridden with the configured @t{pprio}, the value of
                        priority in the VLAN-tag is unchanged.
	@item @i{VLAN tag}: are discarded
	@item @i{null tag}: are discarded

    @end itemize
    @item Mode @t{TRUNK} (0x1), frames with:
    @itemize
	@item @i{no VLAN-tag}: are discarded
	@item @i{priority tag}: are discarded
	@item @i{VLAN tag}: are admitted; if @t{pprio} is not -1, the value of
			priority provided to RTU is overridden with
			the configured @t{pprio}, the value of
                        priority in the VLAN-tag is unchanged.
	@item @i{null tag}: are discarded

    @end itemize
    @item Mode @t{DISABLED} (0x2), frames with:
    @itemize
	@item @i{no VLAN-tag}: are admitted. No other configuration is used even
			if set.
	@item @i{priority tag}: are admitted; if @t{pprio} is not -1, the value
			of priority provided to RTU is overridden with
			the configured @t{pprio}
	@item @i{VLAN tag}: are admitted; if @t{pprio} is not -1, the value of
			priority provided to RTU is overridden with
			the configured @t{pprio}
	@item @i{null tag}: are admitted; if @t{pprio} is not -1, the value of
			priority provided to RTU is overridden with
			the configured @t{pprio}
    @end itemize
    @item Mode @t{UNQUALIFIED} (0x3), frames with:
    @itemize
	@item @i{no VLAN-tag}: are admitted. No other configuration is used even
			if set.
	@item @i{priority tag}: are admitted. The value of VID in their VLAN-tag is
                        overridden with the value configured in n @t{pvid}. This
                        new value of VID is provided to the RTU. If @t{pprio} is
                        not -1, the value of priority provided to RTU is
                        overridden with the configured @t{pprio}, the value of
                        priority in the VLAN-tag is unchanged.
			@b{Note:} From version v6.0, providing a VID for this mode
			is supported in the dot-config, "Raw ports configuration"
			needs to be enabled.
	@item @i{VLAN tag}: are admitted; if @t{pprio} is not -1, the value of
			priority provided to RTU is overridden with
			the configured @t{pprio}
	@item @i{null tag}: discarded.
    @end itemize
@end itemize

Modes and their behavior are summarized in the table below:

@center @image{VLAN_modes, 14cm,, VLAN_modes}

@b{The best and recommended way to configure VLANs is to use the @i{wrs_menuconfig}
tool for generating the @t{dot-config} file.} The @t{dot-config} file is used at
startup to set:
@itemize
  @item @i{per-port and per-VLAN} configuration - the @t{dot-config} is read
   by the @i{wrs_vlans} tool at startup
  @item @i{PPSi PTP VLAN configuration} - the @t{ppsi.conf} file is generated
   at startup from the @t{dot-config} file, it is then read by PPSi.
@end itemize
For an example configuration using @i{wrs_menuconfig} and @t{dot-config},
please see @ref{Example VLAN configuration by dot-config}).

An alternative for VLAN configuration, especially when experimenting with VLANs,
is to use the  @i{wrs_vlans} tool directly and to provide a custom @t{ppsi.conf}.
Beware that this method is more error-prone.

To have synchronization working with VLANs, a proper PTP VID needs to be
provided for ports in TRUNK, DISABLED and UNQUALIFIED mode. In the @t{dot-config}
file, it is the @t{CONFIG_VLANS_PORT@i{xx}_PTP_VID} configuration option. For
ports in ACCESS mode, the PTP VID is derived from the VID
(@t{CONFIG_VLANS_PORT@i{xx}_VID} in the @t{dot-config} file).
As an alternative you can write a custom @i{PPSi} configuration file with 
VLANs specified per-port.
You can simply copy the file generated in the WRS filesystem
(@i{/etc/ppsi.conf}) to a central @t{tftp}/@t{http}/@t{ftp} server where
@t{dot-config} files for your switches are stored and fetched on boot time or
permanently store it in the flash (for details, please check the
configuration options @t{CONFIG_PTP_*} in the
@ref{Configuration Items that Apply at Run Time}).

In the @i{PPSi} config file, for every VLAN-enabled port you should add
the following line:
where @i{VID} is a VLAN ID configured on the port.

For an example configuration please see
@ref{Example VLAN configuration by tools}).


From the firmware v5.0, configuration of VLANs via the @t{dot-config} file was
possible with some limitations/simplifications which made the life of the user easier
but prevented some exotic VLAN configurations. From the firmware v6.0, all 
possible configuration can be set via dot-config. By default, the more
user-friendly configuration is used (similar to the one in v5.0). To have
full control over VLAN configuration, "raw ports configuration" must be enabled.

Another alternative working on pre-v5.0 to set VLANs is to use the web
interface. However, as it is in v5.0, the web-interface is not capable to store
VLANs configuration into a @t{dot-config}.


@c =-------------------------------------------------------------------------
@node Example VLAN configuration
@subsection Example VLAN configuration

This section describes how to configure VLANs on a switch using the
@t{dot-config} and available command line tools.
The description assumes that switch has only these 3 ports.
In this configuration, port 1 is synchronized to an upstream WR device. This
device does not need to have any VLAN configuration. Port 1 is in @t{ACCESS} mode,
thus it tags the ingress Ethernet frames. VLAN-tags with VID 1 and priority
4 are added so that frames received at this port belong to VLAN 1. Port 1 also
untags the egress frames. In this configuration, only port 1
belongs to VLAN 1, which means that none of the traffic received on port 1 is
forwarded to other ports. The only traffic received on port 1 that is not
dropped are the PTP messages which are forwarded to the PTP daemon (@i{PPSi}). Such
an arrangement can be useful if the synchronization is to be propagated through
WR network, i.e. between the upstream and this switch, but the data needs to be
separated.

The data is forwarded between ports 2 and 3. These ports belong to VLAN 2
(VID=2). Port 3 is in @t{ACCESS} mode and it tags the ingress frames with VID 2
and priority 7. This could be a port connected to a WR node that is a source of
critical traffic. This WR node does not need to support VLANs, however its
traffic needs to have the highest precedence in the network.

The traffic from port 3 is forwarded only to port 2. This port is in @t{TRUNK}
mode. It does not untag egress frames which means that the device connected to
it (a switch or a node) must be VLAN-aware. Port 2 accepts only frames that are
already tagged with the VLAN-tag. Out of the frames received at port 2, only
these with VID=2 are forwarded, all the other frames are dropped. The
frames with VID=2 are forwarded to PTP daemon and to port 3.

@c =-------------------------------------------------------------------------
@node Example VLAN configuration by dot-config
@subsubsection Example VLAN configuration by dot-config

To configure the switch in the way described in the
@ref{Example VLAN configuration}, the @i{wrs_menuconfig} tool should
be used to generate the @t{dot-config} file. In the @i{wrs_menuconfig} tool,
VLANs needs to be enabled in the VLANs submenu. Then, the Ports and VLANs
configurations need to be filled in properly, as can be seen in the figure
below.

@center @image{Example_VLAN_config, 16cm,, Example_VLAN_config}


Such generated @t{dot-config} file will contain the following config options
(and much more, of course):
PTP_OPT_EXT_PORT_CONFIG_ENABLED=yes
# Port 1 configuration
CONFIG_PORT01_IFACE="wri1"
CONFIG_PORT01_FIBER=0
CONFIG_PORT01_INSTANCE_COUNT_1=yes
CONFIG_PORT01_INST01_PROTOCOL_RAW=yes
CONFIG_PORT01_INST01_PROFILE_WR=yes
CONFIG_PORT01_INST01_DESIRADE_STATE_SLAVE=yes
CONFIG_PORT01_INST01_EGRESS_LATENCY=0
CONFIG_PORT01_INST01_INGRESS_LATENCY=0
...
# Port 2 configuration
CONFIG_PORT02_IFACE="wri2"
CONFIG_PORT02_FIBER=0
CONFIG_PORT02_INSTANCE_COUNT_1=yes
CONFIG_PORT02_INST01_PROTOCOL_RAW=yes
CONFIG_PORT02_INST01_PROFILE_WR=yes
CONFIG_PORT02_INST01_DESIRADE_STATE_MASTER=yes
CONFIG_PORT02_INST01_EGRESS_LATENCY=0
CONFIG_PORT02_INST01_INGRESS_LATENCY=0
...
# Port 3 configuration
CONFIG_PORT03_IFACE="wri3"
CONFIG_PORT03_FIBER=0
CONFIG_PORT03_INSTANCE_COUNT_1=yes
CONFIG_PORT03_INST01_PROTOCOL_RAW=yes
CONFIG_PORT03_INST01_PROFILE_WR=yes
CONFIG_PORT03_INST01_DESIRADE_STATE_MASTER=yes
CONFIG_PORT03_INST01_EGRESS_LATENCY=0
CONFIG_PORT03_INST01_INGRESS_LATENCY=0
...
# Vlans configuration
CONFIG_VLANS_ENABLE=y
CONFIG_VLANS_PORT01_MODE_ACCESS=y
CONFIG_VLANS_PORT01_UNTAG_ALL=y
CONFIG_VLANS_PORT01_PRIO=4
CONFIG_VLANS_PORT01_VID="1"
CONFIG_VLANS_PORT02_MODE_TRUNK=y
CONFIG_VLANS_PORT02_PTP_VID="2"

CONFIG_VLANS_PORT03_MODE_ACCESS=y
CONFIG_VLANS_PORT03_UNTAG_ALL=y
CONFIG_VLANS_PORT03_PRIO=7
CONFIG_VLANS_PORT03_VID="2"
CONFIG_VLANS_VLAN0001="fid=1,prio=4,drop=n,ports=1"
CONFIG_VLANS_VLAN0002="fid=2,prio=4,drop=n,ports=2;3"

NOTE: It is highly discouraged to modify the @t{dot-config} file by hand.
It is very error-prone.

@c =-------------------------------------------------------------------------
@node Example VLAN configuration by tools
@subsubsection Example VLAN configuration by tools

To configure the switch in the way described in the
@ref{Example VLAN configuration}, using the @i{wrs_vlans} command line tool
and custom @t{ppsi.conf} file, please perform the following actions:
Clear the current configuration:
@smallexample
# wrs_vlans --clear
# wrs_vlans --rvid 0 --del
@end smallexample

Set ports' configuration by using the @t{wrs_vlans} tool:
@smallexample
# wrs_vlans \
    --port 1 --pmode 0 --pprio 4 --pvid 1 --puntag 1 \
    --port 2 --pmode 1 --pprio -1  \
    --port 3 --pmode 0 --pprio 7 --pvid 2 --puntag 1
Set VID configuration by using the @t{wrs_vlans} tool:
@smallexample
# wrs_vlans \
    --rvid 1 --rprio 4 --rdrop 0 --rmask 0x00001 \
    --rvid 2 --rprio 4 --rdrop 0 --rmask 0x00006
@end smallexample

For details about @t{wrs_vlans} please refer to the @ref{wrs_vlans}.

@i{PPSi} configuration that should be placed into @t{ppsi.conf}:
@smallexample
port wri1-raw
proto raw
iface wri1
desiredState  slave
profile  wr
desiredState  master
profile  wr
desiredState  master
profile  wr
NOTE: The @t{ppsi.conf} in /etc/ folder is automatically generated from the
@t{dot-config} file on startup, thus you will loose your changes if you
update directly @t{ppsi.conf} in /etc/. To use custom @t{ppsi.conf}, you
need to specify its path in dot-config using the parameter:
CONFIG_PTP_CUSTOM.

@c ==========================================================================
@node Front panel's LEDs
@section Front panel's LEDs

There are two LEDs on the front panel describing switch status and two LEDs for
each WR port. Each LED can be off, green or orange color, or the
combination of both giving yellow.
For more details please refer to following sections.

@c =-------------------------------------------------------------------------
@node Status LEDs
@subsection Status LEDs

The status LED is placed together with power indicator LED on the left side of
the front panel. The status LED is the right one.
During barebox/kernel boot the status LED is off. When @t{startup-mb.sh} starts
the LED is set to yellow. If the HAL starts successfully then the LED is set to
green. If the HAL caught a SIGNAL (error) sent by other process, HAL sets the status
When the regular reboot is performed status LED is turned off. In case of
a kernel crash the LED remains unchanged.

@c =-------------------------------------------------------------------------
@node Ports' LEDs
@subsection Ports' LEDs

Under each WR port there are two LEDs, left and right. The left LED has two
functions. First: it blinks @i{orange} when a particular port is populated
with an SFP and the Low Phase Drift Calibration is ongoing; this happens after
inserting a fiber and after the WR switch start/reboots.
Second: it is on (permanently, not blinking) when a particular
port is populated with an SFP and the link is up. Its color depends on
the state of PTP instance running on the port:
    @item @i{green}: WR slave
    @item @i{yellow}: WR master
    @item @i{orange}: all other
If there are multiple instances on a particular port the slave state (green)
takes precedence over master (orange). Master takes precedence over other
states (yellow).
The right LED is green when a particular port is synchronized to the master.
When a packet is transmitted or received on a port the right LED blinks orange.
If a port is also synced then it blinks yellow instead.

@c ############################################################################
@node Booting with Barebox
@chapter Booting with Barebox

After the initial installation, the boot loader offers an
interactive  menu, where the first entry is selected by default.
The menu is a simple ASCII interface on the serial port, and looks
like the following:

@example
   Welcome on WRSv3 Boot Sequence
       1: boot from nand (default)
       2: boot from TFTP script
       3: edit config
       4: exit to shell
       5: reboot
@end example

If flashing of the whole system was successful, the first entry will
simply work, booting the switch without any network access.  Although
Alessandro Rubini's avatar
Alessandro Rubini committed
a DHCP client runs by default after boot, everything will work even if
you leave the Ethernet port unconnected or you have no DHCP server
when the switch is operational.

If booting from NAND memory fails (for example because you erased the
kernel or incurred in other mishaps during development)
the menu is re-entered automatically.

The other entries are provided to help developers.

@c ==========================================================================
@node Description of the menus
@section Description of the menus

The individual menu items perform the following actions:
@table @code

@item 1: boot from nand (default)

	This entry is selected by default after 5 seconds of
        inactivity on the serial port. It boots the system from its
        own NAND memory. This ``just works''.

@item 2: boot from TFTP script

	This entry tries to download a @i{barebox} script from your TFTP
        server; if successful it then executes it. Developers are
        expected to customize the script to support any kind of environment,
        from customized kernel command-line to NFS-Root environments.
        See @ref{Using wrboot} for details.

@item 3: edit config

	This fires the editor on the configuration file, and
        saves it to flash when the user is done. This may be useful to
        change the MAC or IP address of the ARM network port, change the
        autoboot timeout or change the autoselect choice. Please note
        that saving save the whole @file{/env} file tree, so you
        can also change the init scripts interactively and have them
        stored persistently on the flash. Users are not expected to
        change any configuration, though, as further updates may fail.

@item 4: exit to shell

	By choosing this entry, the user can access the shell-like
        interface of @i{barebox}. The entry is aimed at developers
        who know what they are going to type.

@item 5: reboot

	This entry is useful to see and log the exact boot messages.
        Since the serial-USB converter is @i{switch-powered} and not
        @i{USB-powered}, you won't be able to hook at the serial port
        soon enough after power-on.  Actually, the menu startup time
        is a few seconds long for the very same reason.

@end table

@c ==========================================================================
@node Using wrboot
@section Using wrboot

If you use the @i{wrboot} script option, you can for example run
an NFS-Root system or do whatever customization and testing you want.

@b{Note}: with the Linux kernel 2.6.39 we suggested use of @t{root=nfs}, but
this convention is no more supported in Linux, please use @t{root=/dev/nfs}.
The complete filesystem after a successful build is called
@t{images/wrs-image.tar.gz}, and is not included in the release
firmware file, because an installed switch runs an @i{initramfs}
system with a separate @t{/usr} partition in flash memory.

@sp 1

The @i{boot from TFTP script} menu entry looks for the script
using three
different names, from most specific to most generic; the first found
is be used.  When using the boot script, the @sc{wrs} first performs
a @sc{dhcp} query, and then uses that IP address to retrieve
the script using the following names (the @t{eth0.ethaddr} is
stored by the manufacturer in static storage and retrieved by the
boot loader; the @t{eth0.ipaddr} comes from @sc{dhcp}):
@smallexample
   wrboot-$eth0.ethaddr
   $eth0.ipaddr/wrboot
   wrboot
@end smallexample

As an example, the following excerpt shows what I see in my logs when
only providing @file{wrboot}.  The last message uses a different IP
address because my script forces a static address into the kernel,
whereas the initial one was assigned to the boot loader using
@sc{dhcp}.

@smallexample
   dhcpd: DHCPOFFER on 192.168.16.224 to 02:0b:ad:c0:ff:ee via eth0
   atftpd[5623]: Serving wrboot-02:0B:AD:C0:FF:EE to 192.168.16.224:1029
   atftpd[5623]: Serving 192.168.16.224/wrboot to 192.168.16.224:1030
   atftpd[5623]: Serving wrboot to 192.168.16.224:1031
   mountd[21014]: NFS mount of /tftpboot/192.168.16.9 attempted from 192.168.16.9
@end smallexample

We chose to place the IP-address-based name in a subdirectory because
this is the default place where the NFS-Root filesystem is mounted
from, as shown in the log excerpt above. So you'll have your
@file{wrboot} in the same place.

Note that the IP address of the TFTP server can be specified using the DHCP
@t{next-server <address>} configuration option.

@b{Note:} recent @i{barebox} versions require scripts to include a
leading @t{#!/bin/sh}. Examples in @i{wr-switch-sw} did not include the
line until April 2014 included.

The @file{binaries} subdirectory of @t{wr-switch-sw} includes a number
of known-working wrboot scripts as examples;
@table @t

@item wrboot-static-ip

	The script forces a static IP address, server and gateway, and
        a custom mount point for an NFS-root system.

@item wrboot-dhcp

	The script preserves the @sc{dhcp}-assigned address, and runs
        a custom NFS-root system.

@item wrboot-install

	This performs an installation, by loading everything to RAM
        and forcing install mode. Please check comments in the script.

@item wrboot-nand

	This script is a copy of the default boot script executed
        by standalone switches.  Booting from a script allows
        changing the kernel command line or anything else it may
        be useful to developers.

@end table
@c ==========================================================================
@node Creating an NFS-Root Environment for WRS
@section Creating an NFS-Root Environment for WRS

In order to create an NFS root directory, you should uncompress
@t{wrs-image.tar.gz} that is created at build time in a newly-created
empty directory:

@example
   tar xzf $WRS_OUTPUT_DIR/images/wrs-image.tar.gz
@end example

If you use
a released @t{wrs-firmware.tar}, however, you'll have no overall
filesystem for the switch, and you should rebuild it from two
parts.  This is how to create your NFS filesystem from a
released @t{wrs-firmware} file (please adapt
for your local pathnames):

@example
   FW=/tftpboot/wrs-firmware.tar
   DIR=/opt/root/wrs-3

   mkdir -p $DIR
   tar xOf $FW wrs-initramfs.gz | zcat | \
       (cd $DIR && sudo cpio --make-directories --extract)
   tar xOf $FW wrs-usr.tar.gz | sudo tar xzf - -C $DIR/usr
@end example

The above commands extract to @i{stdout} the two parts of the @sc{wrs}
filesystem, to then uncompress them to the proper directories.  The
first @i{tar} pipe is less friendly because the @i{initramfs} is a
compressed @i{cpio} archive, and @i{cpio} as a command lacks automatic
decompression and the @t{-C} (change directory) option.


@c ##########################################################################
@node WRS Command-Line Tools
@chapter WRS Command-Line Tools



are build from source files in @file{userspace/tools} while the
scripts are copied directly from @file{userspace/rootfs_override/wr/bin}.

The following tools and scripts are provided:

@table @file

@item apply_dot-config
	The script is used to apply @t{dot-config} settings to the
	current configuration files.  It is run at boot time before
	any service is started and by the web interface to apply changes in
	the local @t{dot-config}.
	The @t{dot-config} mechanism is documented in
	@ref{Configuration of the Device}.

@item assembly_ppsi_conf.sh
	The script is used to assembly ppsi configuration file based on
	information stored in @t{dot-config}.
	This script is called by @t{apply_dot-config}.

@item assembly_snmpd_conf.sh
	The script is used to assembly SNMP daemon's configuration file based on
	information stored in @t{dot-config}.
	This script is called by @t{apply_dot-config}.

@item change_dot-config
	This script changes the current @t{dot-config} file. It is
	designed to be the back-end of the web interface, when changing
	configuration items.  The script does nothing to @i{apply}
	the changes, and it only performs editing.
	It is the responsibility of the caller to ensure the proper
	service is restarted with the new configuration.

@item com
	The program is a simple program for talking with serial ports.

@item ethtool
	The standard Linux tool used to query or control network driver and
	hardware settings. In WRS the number of parameters that this tool can
	change is limited. However, this tool can be used on WRS with the
	following commands:
	``@t{ethtool -s wriX autoneg off}'' disables (or enable if @t{on})
	autonegotiation @footnote{WRS does not support other link speeds
	than 1Gbps, thus when autonegotiation is enabled, no other link speed
	can be actually negotiated}

	``@t{ethtool --set-priv-flags wriX "Unidirectional Enable" on}'' enables
	(or disables if @t{off}) transmission regardless of whether a valid
	link has been established

	``@t{ethtool --set-priv-flags wriX "Accept RX Jumbo Frames" on}''
	accepts (or drops if @t{off} is used) RX Jumbo Frames

@item lm32-vuart
	The tool allows connecting to the virtual UART of the LM32 soft-core CPU.
	It can be used to observe log messages from the SoftPLL (the same as
	@i{FPGA Test}
	physical UART port available in the back of a WR switch). Use
	@code{Ctrl+C} escape combination to go back to WR Switch Linux shell.

@item load-lm32
@itemx load-virtex
	They load into the FPGA the gateware and the LM32 application.
	They are used by the init scripts of the Linux system. The LM32
	loader can also change variables in the loaded binary, and
	read or write variables without stopping the running CPU.
	This is limited to 32-bit integer variables, though. 
@c FIXME: document better load-lm32 for elf.

@item mapper
@itemx wmapper
	The former reads from a file using @i{mmap}
	(usually you run it on @i{/dev/mem}) and writes to @i{stdout}.
	The latter reads from @i{stdin} and writes using @i{mmap}.
	They are classic tools distributed in the @i{Linux Device Drivers}
	examples since 1998.
@item ppsi_conf
	The tool that can be used to change some of PPSi's parameters in
	runtime.
	Some parameters that can be changed are global (e.g. @t{priority1},
	@t{servo tracking}), other are specific for PPSi instance
	(e.g. @t{delay-req-interval}, @t{sync-interval}).
	This tool supports a change of parameter's value for all instances on
	a given port or for all existing instances.

	NOTE: This tool can be used to change in runtime diagnostics level
	(verbosity) of PPSi, global and per instance.

	For more information about supported parameters please refer to
	PPSi's documentation or tool's help (@t{--help} parameter).

@item ptpdump
	This is a sniffer for @sc{ptp} frames. It reports all Ethernet frames
	and UDP datagrams that talk @sc{ptp}, from a specific network interface.
	The output format is line-oriented to help running @i{grep} over log
	files.
	The number of blank lines between frames depends on how much time
	elapsed between them; this should help identifying sync/follow-up
	pairs at a glimpse of the eye.

	The program receives one optional argument on the command line, which is
	the name of the interface where it should listen; by default it uses
	@t{eth0}.

@item rtu_stat
	The tool allows to configure switching rules
	for each port via RTU daemon. The @t{--help} option
	lists all configuration items of the tool.

@item rvlan-status
@item rvlan-debug

	The tools allow to check status, as well as debug and throttle verbosity
	of the Radius Vlan mechanism, if enabled. See details in a separate
	manual: @i{White Rabbit Switch: Radius Vlan}.


	The tool, copied from the @t{fpga-config-space} project.
	For details please refer to the @ref{sdb-read}.

@item shw_ver
	A symbolic link to @t{wrs_version}, to be compatible with
        older versions that used this tool name. The name is
        inconsistent with anything else in the switch, so it was
        replaced.
@anchor{wr_date}
	The program can read or set the White Rabbit date. Usage:

	``@t{wr_date set} @i{value}'' sets an arbitrary date and time as the system time,
	``@t{wr_date set host}'' passes the host time to White Rabbit.
	If the file @t{/etc/leap-seconds.list} exists, it is used to
	pass the TAI offset to the kernel, and to consider it in setting
	White Rabbit time to the current TAI value.  The program is
	meant to prime the White Rabbit counter at boot time, and is
	run by @t{/etc/init.d/wr_date} -- this script uses NTP
	to set host time as a first step, if @t{/etc/wr_date.conf}
	exists and includes a line of the form @t{ntpserver 192.168.16.1}.
	The file @t{/etc/wr_date.conf} is created at boot time by the script
	@t{apply_dot-config} if a NTP server is defined (@t{CONFIG_NTP_SERVER}).
	With ``@t{wr_date get}'' you can read White Rabbit time, and
	by using @t{wr_date get tohost}'' you can set host time from
	White Rabbit time. This can be useful in slave switches that
	are not synced to NTP at boot.
@item wr_mon
	A simple monitor of White Rabbit status. It prints to @i{stdout}
	using the standard escape sequences for color output. Please check
	@t{wr_mon}'s help (@t{--help} parameter) for further information.
	(This is probably the most important diagnostic tool on the switch.)
@item wr_phytool
	A tool to read and write PHY registers in the switch.
@item wrs_auxclk
	The tool allows to setup the parameters of a clock generated on the
	@i{clk2} SMC output on the front panel.
	For details please refer to the @ref{wrs_auxclk}.
@item wrs_checkcfg
	Simple program performing a basic validation of a @t{dot-config}.
	Used during startup for validation of a received @t{dot-config}.

@item wrs_dump_shmem
	Probably the most useful tool for advanced debugging of a switch.
	It can dump and interpret many internal variables from HAL, rtud, PPSi
	and SoftPLL.
	The output is presented in a grep-friendly format as "@t{NAME: VALUE}".
	Please check its help (@t{--help} parameter) for more information.

@item wrs_leapsec
	This tools read the local time and checks for an incoming leap second.
	If it detects a incoming leap seconds in the next 12 hours,
	the information is set in the kernel and will be available for PPSi.

@item wrs_menuconfig
@itemx wrs_nconfig
	wrs_menuconfig and wrs_nconfig use a different framework to display and
	change switch configuration.
	This is the preferred way over manual editing of @t{dot-config},
	since menuconfig can preserve number of constraints on values and
	between configuration items.
	Please make sure that after the changes are done, the local config
	is configured to be used
	(configuration item @t{CONFIG_DOTCONF_SOURCE_LOCAL}).

@item wrs_pps_control
	A tool to manually enable/disable/read status of  PPS output.
	It can also enable/disable/read status of the 50ohm termination for 1-PPS input.
	Usage:
	``@t{wrs_pps_control pps on}'' enables the PPS output,
	``@t{wrs_pps_control pps off}'' disables the PPS output,
	``@t{wrs_pps_control pps read}'' checks whether PPS output is enabled or disabled.

	Switching the output on/off is independent
	of the PPSi process, but PPSi switches the PPS output back on when a
	link restart is detected and PPSi comes into @t{'TRACK_PHASE'} state.
	To on/off/read the 50ohm termination for 1-PPS input use
	@t{wrs_pps_control} with a parameter @t{50ohm-term-in} followed by
	@t{on}, @t{off} or @t{read}.
@item wrs_pstats
	The tool is used to read various per-port statistics counters from the
	console. Please note that the same values are also provided through SNMP
	objects.
	For details please refer to the @ref{wrs_pstats}.
	Dump the content of SFPs internal memory. This tool can read SFP info
	from HAL's shmem or directly from SFPs via i2c bus. Please note that
	reading directly via i2c can cause race condition on i2c bus. The tool is not
	recommended to be used in production.
	The race condition can cause errors while reading SFPs memory,
	wrong notification of LEDs, the false insert/remove SFP notifications.

	This tool can also write SFPs internal memory. This functionality can
	be used to fix SFPs reporting i.e. wrong checksum. Use this option with
	care.
	
	For more details please refer to the tool's help.
@item wrs_status_led
	Simple tool used during startup and restart to control the status LED.

@item wrs_throttling
	The tool is used to control Rx bandwidth throttling of the traffic that
	goes from WR ports to Linux. It configures the FPGA module with a
	maximum allowed bandwidth in KB/s. Throttling can be enabled to prevent
	Linux using 100% of the processing power to receive Ethernet frames
	coming from WR ports to the CPU. This tool is executed by default at
	boot time with parameters from the dot-config. For more
	information, please refer to the
	@ref{Configuration Items that Apply at Run Time}.
@item wrs_version
	Print information about the software, gateware, hardware version of the WRS.
	Please check the help message.
@item wrs_vlans
	The tool allows to configure VLAN settings
	for each port and for the RTU daemon. The @t{--help} option
	lists all configuration items of the tool. For details please
	refer to the @ref{wrs_vlans}.
@item wrs_watchdog
	A daemon used to reset the SWcore HDL if there is still some hidden bug
	inside. The number of occurred timeouts can be read using
	@t{-g} parameter and is also reported via SNMP in
	@t{WR-SWITCH-MIB.txt::wrsGwWatchdogTimeouts}.
@c FIXME: document rtu_stat spll_dbg_proxy
@end table

@c --------------------------------------------------------------------------
@node sdb-read

[Note: this documentation section comes from the @t{ohwr} project
called @t{fpga-config-space}.]


The @i{sdb-read} program can be used to access an @i{sdbfs} image
stored in a disk file or an FPGA area in physical memory.
It works both as @i{ls} (to list the files
included in the image) and as @i{cat} (to print to its own @i{stdout}
one of the files that live in the binary image).

The program can be used in three ways:

@table @code

@item sdb-read [options] <image-file>

	This invocation lists the contents of the image. With @code{-l}
        the listing is @i{long}, including more information than the
        file name.

@item sdb-read [options] <image-file> <filename>

	When called with two arguments, the program prints to @i{stdout}
        the content of the named file, extracted from the image. Please
        note that if the file has been over-sized at creation time,
        the whole allocated data area is printed to standard output.

@item sdb-read [options] <image-file> <hex-vendor>:<hex-device>

	If the second argument is built as two hex numbers separated
        by a colon, then the program uses them as vendor-id and device-id
        to find the file.  If more than one file have the same identifiers,
        the @i{first} of them is printed.

@end table

The following option flags are supported:

@table @code

@item -l

	For listing, use @i{long} format. A @i{verbose} format will
        be added later.

@item -e <entrypoint>

	Specify the offset of the magic number in the image file.

@item -m <size>@@<addr>
@itemx -m <addr>+<size>

	Either form is used to specify a memory range. This is the
        preferred way to read from a memory-mapped area, like an FPGA
        memory space.  Please note that in general you should not
        read a ``file'' in FPGA space, because this would mean read
        all device registers. The form ``@t{<image-file> <filename>}''
        is thus discouraged for in-memory SDB trees (i.e. where
        @t{<image-file>} is @t{/dev/mem}).

@item -r

	Register the device with a @i{read} method instead of the @i{data}
        pointer. In this way the
        tool can be used to test the library with either access method.
        If @i{mmap} fails on the file (e.g., it is a non-mappable device),
        @i{read} is used automatically, irrespective of @t{-r}.

@end table

@c --------------------------------------------------------------------------
@node wrs_auxclk
@section wrs_auxclk

The @i{wrs_auxclk} shell tool can be used to configure parameters of a clock
signal generated on the @i{clk2} SMC connector on the front panel.

@b{Note:} You need to have WRS hardware at least in version 3.4 to have @i{clk2}
output.

By default @i{wrs_auxclk} is called by init scripts to generate 10MHz clock
signal with 50% duty cycle. This configuration can be modified by using various
options:

@table @code

@item --freq <f>
  Desired frequency of the generated clock signal in MHz. Available range from
  4kHz to 250MHz.

@item --duty <frac>
  Desired duty cycle given as a fraction (e.g. 0.5, 0.4).

@item --cshift <csh>
  Coarse shift (granularity 2ns) of the generated clock signal. This parameter
  can be used to get desired delay relation between generated 1-PPS and
  @i{clk2}. The delay between 1-PPS and @i{clk2} is constant for a given
  bitstream but may be different for various hardware versions and
  re-synthesized gateware. Therefore it should be measured and adjusted only
  once for given hardware and gateware version.

@item --sigdel <steps>
  Clock signal generated from the FPGA is cleaned by a discrete flip-flop.
  It may happen that generated aux clock is in phase with the flip-flop clock.
  In that case it is visible on the oscilloscope that @i{clk2} clock is
  jittering by 2ns. The @code{--sigdel} parameter allows to add a precise delay
  to the FPGA-generated clock to avoid such jitter. This delay is specified in
  steps, where each step is around 150ps. This value, same as the
  @code{--cshift} parameter, is constant for a given bitstream so should be
  verified only once.

@item --ppshift <steps>
  If one needs to precisely align 1-PPS output with the @i{clk2} aux clock using
  @code{--cshift} parameter is not enough as it has 4ns granularity. In that
  case @code{--ppshift} lets you shift 1-PPS output by a configured number
  of 150ps steps. However, please have in mind that 1-PPS output is used as a
  reference for WR calibration procedure. Therefore, once this parameter is
  modified, the device should be re-calibrated. Otherwise, 1-PPS output
  will be shifted from the WR timescale by <steps>*150ps.


@end table

@c --------------------------------------------------------------------------
@node wrs_pstats
@section wrs_pstats

The @i{wrs_pstats} shell tool can be used to read per-port statistics counters
from FPGA. When it is executed without any parameters all displayed values are
counted from the moment the tool was started. In case you're interested in the
values gathered from the start of WR switch, you can use @i{-s} option. The
following counters for each port are reported:

@multitable @columnfractions .18 .8
@headitem Counter @tab Description
@item @code{0:Tu-run} @tab Number of TX underrun errors
@item @code{1:Ro-run} @tab Number of RX overrun errors
@item @code{2:Riv-cd} @tab Number of invalid 8B10B characters received
@item @code{3:Rsyn-l} @tab Number of RX link synchronization lost events
@item @code{4:Rpause} @tab Number of received pause frames
@item @code{5:Rpf-dp} @tab Number of received frames dropped by the Packet Filter
@item @code{6:Rpcs-e} @tab Number of PCS errors during frame reception
@item @code{7:Rgiant} @tab Number of received giant frames
@item @code{8:Rrunt} @tab Number of received runt frames (smaller than 64 bytes)
@item @code{9:Rcrc_e} @tab Number of CRC errors in received frames
@item @code{10-17:Rpcl_0-7} @tab Number of received frames qualified by Packet Filter to classes 0 to 7
@item @code{18:Tframe} @tab Number of transmitted frames
@item @code{19:Rframe} @tab Number of received frames
@item @code{20:Rrtu_f} @tab Number of RX frames dropped due to RTU full
@item @code{21-28:Rpri_0-7} @tab Number of received 802.1Q frames with priorities 0 to 7
@item @code{29:RTUreq} @tab Number of RTU requests
@item @code{30:RTUrsp} @tab Number of RTU responses
@item @code{31:RTUdrp} @tab Number of frames dropped by the RTU
@item @code{32:RTUhp} @tab Number of high priority frames routed by RTU
@item @code{33:RTUf-f} @tab Number of forwarded frames matched by RTU fast match engine
@item @code{34:RTUn-f} @tab Number of not forwarded frames matched by RTU fast match engine
@item @code{35:RTUfst} @tab Number of RTU fast match decisions
@item @code{36:RTUful} @tab Number of RTU full match decisions
@item @code{37:RTUfwd} @tab Total number of frames forwarded by RTU
@item @code{39:NIC_Tx} @tab Number of frames sent from WR Switch ARM to that port

@end multitable

@c --------------------------------------------------------------------------
@node wrs_vlans
@section wrs_vlans

The @i{wrs_vlans} shell tool can be used to setup VLANs in the switch.
The configuration can be read from the @t{dot-config} file pointed by @t{-f} or
@t{--file} parameter (for @t{dot-config} details please check
@ref{Configuration Items that Apply at Build Time}).
Additionally, the configuration can be specified using parameters below.
The details of VLANs configuration are discussed in
@ref{VLANs Configuration}.
The @i{wrs_vlans} configuration is divided into two parts:
@item wrs_vlans --port <port number or range> [options]

  Per-port Endpoint VLAN configuration. Used to set VID and priority for ingress
  frames tagging, egress untagging and port mode. For port modes please refer
  to the @ref{VLANs Configuration}.

@item wrs_vlans --rvid <vid> [options]

  Per-VLAN configuration of the Routing Table Unit, used to configure port mask
  describing which ports belong to a given VLAN. RTU uses this information to be
  able to forward incoming frames only to ports inside the VLAN.

@end table

Both per-port Endpoint and per-VLAN RTU configuration has to be performed in
order to have a full VLAN setup on a WR Switch.

For per-port configuration, multiple ways of specifying ports are supported:
@table @code


  Selected configuration will be applied only to port 1.

@item wrs_vlans --port 1,3,4 [options]

  Selected configuration will be applied to ports 1,3 and 4.

@item wrs_vlans --port 5-8 [options]

  Selected configuration will be applied to port range 5 to 8.

@item wrs_vlans --port 5-8,15 [options]

  Selected configuration will be applied to port range 5 to 8 and port 15.

@end table

To configure each Endpoint the following options may be used:
@table @code

  Sets VLAN mode for a port (@t{0} -- @t{ACCESS}, @t{1} -- @t{TRUNK},
  @t{2} -- @t{DISABLED}, @t{3} -- @t{UNQUALIFIED})
  Sets VLAN id for tagging ingress frames.

@item --pprio <-1|0..7>
  Sets priority for tagging ingress frames. @t{-1} disables priority overwrite.
@item --puntag <0|1>
  Disables or enables egress untagging. By default, if you configure ingress
  tagging, all VIDs are untagged on egress.

@end table

To configure VLANs in RTU the tool has to be used with parameter specifying
VLAN id to be set up and then the list of configuration options:
@table @code
@item wrs_vlans --rvid <vid> [options]
@end table

Possible RTU VLAN configuration options:
@table @code

@item --rmask <0x0..0x3ffff>
  Mask defines which physical ports of the WRS belong to a configured VLAN.

  Assigns filtering ID @i{fid} to the configured VLAN. Multiple VLANs can be
  configured to have the same @i{fid}. This way they create a group where
  learning a new MAC address in one VLAN implies learning this MAC in the rest
  of VLANs in the group as well.

@item --rprio <-1|0..7>
  Forces 802.1q priority override for VLAN. Setting @i{prio} to @t{-1}, cancels
  the override.

@item --rdrop <1/0>
  Forces (if set to 1) or disables (if set to 0) frames drop for the configured
  VLAN.

@item --del
  Deletes selected VLAN from the RTU configuration.

@end table

In addition to that @i{wrs_vlans} can be also used to display and clear current
VLAN configuration of the switch:

@table @code


@item wrs_vlans --list

  Current RTU VLAN configuration.

@item wrs_vlans --clear

  Clear configuration. Add a default rule to pass all traffic between ports.
@end table

@i{wrs_vlans} tool can be called multiple times to make a set of per-port and
per-VLAN configurations. However, it is also possible to configure multiple
ports/VLANs in one go. For example to configure ports 1,2,3,6 to VLAN 5 and
ports 4,5 to VLAN 6 with tagging ingress frames one could call @i{wrs_vlans}
  wrs_vlans --port 1-3,6 --pmode 0 --pvid 5 --port 4,5 --pmode 0 --pvid 6 \
    --rvid 5 --rmask 0x27 --rvid 6 --rmask 0x18
@end example

@b{Note:} The above operation is not atomic, i.e. the configuration will be
applied to one port at a time.

@c ##########################################################################
@node SNMP Support
@chapter SNMP Support

The White Rabbit Switch supports SNMP. The default read-only ``community'' name
is @t{private},
but you can change it from the @t{Kconfig} interface before building.
The default read-write community is @t{private}.

The switch supports all the information through the standard @i{net-snmp}
installation.
In addition it implements the subset of @t{BRIDGE-MIB} (switching table,
defined in RFC 1493),
@t{Q-BRIDGE-MIB} (VLANs entries, defined in RFC 4363) and
@t{LLDP-MIB} (if LLDP is enabled in dot-config).
The OID @t{SNMPv2-MIB::sysObjectID} is filled depending on manufacturer and
hardware version based on the information stored in @t{hwinfo}.
OIDs @t{SNMPv2-MIB::sysContact} and @t{SNMPv2-MIB::sysLocation} can be defined
a free text in dot-config.

The additional, switch-specific information are in the
``@t{enterprise.96.100}'' subtree, where @t{96} is CERN and @t{100} is White
Rabbit. The associated MIB is in the directory @t{userspace/snmpd},
where related source files live as well.

There is currently no support for traps.
@c ==========================================================================
@node The WRS MIB
@section The WRS MIB

This section contain a summary of the @t{WR-SWITCH-MIB}, for details please
refer to the document @i{White Rabbit Switch: Failures and Diagnostics}.
Objects from @t{96.100.2} to @t{96.100.5} are obsolete, they were used during early
implementation of the WRS snmp.

@table @code

@item 96.100.1

	This is a simple scalar as a test. It is an integer value
        that is incremented each time you access it. It can be used to
        test basic functionality.

	@b{wrsStatus} -- MIB's branch with collective statuses of the entire
	switch.

@item 96.100.7

	@b{wrsExpertStatus} -- Branch with detailed statuses of switch
	subsystems.

The easiest way to retrieve the values is using @i{snmpwalk}, telling
it to access our MIB file in order to use symbolic names. Assuming
@t{wrs} is the DNS name for your White Rabbit Switch and @t{WR_SWITCH_SW}
is an environment variable pointing to this package:

@smallexample
   snmpwalk -c public -v 2c wrs \
       -m +$WR_SWITCH_SW/userspace/snmpd/WR-SWITCH-MIB.txt \
       1.3.6.1.4.1.96.100
@end smallexample

Using SNMP version 1 instead of 2c is fine as well, but you won't receive
the 64-bit values for slave/tracking information.

The output you will get, is something like the following:
WR-SWITCH-MIB::wrsScalar.0 = INTEGER: 1
WR-SWITCH-MIB::wrsMainSystemStatus.0 = INTEGER: ok(1)
WR-SWITCH-MIB::wrsOSStatus.0 = INTEGER: ok(1)
WR-SWITCH-MIB::wrsTimingStatus.0 = INTEGER: ok(1)
[...]
WR-SWITCH-MIB::wrsConfigSource.0 = INTEGER: remote(4)
WR-SWITCH-MIB::wrsConfigSourceUrl.0 = STRING: tftp://192.168.1.1/config-192.168.1.10
WR-SWITCH-MIB::wrsBootConfigStatus.0 = INTEGER: ok(1)
WR-SWITCH-MIB::wrsBootHwinfoReadout.0 = INTEGER: ok(1)
WR-SWITCH-MIB::wrsBootLoadFPGA.0 = INTEGER: ok(1)
WR-SWITCH-MIB::wrsBootLoadLM32.0 = INTEGER: ok(1)
[...]
WR-SWITCH-MIB::wrsPtpServoState.1 = STRING: TRACK_PHASE
WR-SWITCH-MIB::wrsPtpServoStateN.1 = INTEGER: trackPhase(4)
WR-SWITCH-MIB::wrsPtpPhaseTracking.1 = INTEGER: tracking(2)
WR-SWITCH-MIB::wrsPtpSyncSource.1 = STRING: 
WR-SWITCH-MIB::wrsPtpClockOffsetPs.1 = Counter64: 0
WR-SWITCH-MIB::wrsPtpClockOffsetPsHR.1 = INTEGER: 0
WR-SWITCH-MIB::wrsPtpSkew.1 = INTEGER: -1
WR-SWITCH-MIB::wrsPtpRTT.1 = Counter64: 943893
WR-SWITCH-MIB::wrsPtpLinkLength.1 = Gauge32: 91
WR-SWITCH-MIB::wrsPtpServoUpdates.1 = Counter32: 33
[...]
WR-SWITCH-MIB::wrsPortStatusPortName.1 = STRING: wri1
WR-SWITCH-MIB::wrsPortStatusPortName.2 = STRING: wri2
[...]
WR-SWITCH-MIB::wrsPortStatusLink.1 = INTEGER: up(2)
WR-SWITCH-MIB::wrsPortStatusLink.2 = INTEGER: up(2)
WR-SWITCH-MIB::wrsPortStatusConfiguredMode.1 = INTEGER: slave(2)
WR-SWITCH-MIB::wrsPortStatusConfiguredMode.2 = INTEGER: auto(4)
WR-SWITCH-MIB::wrsPortStatusSfpVN.1 = STRING: Axcen Photonics
WR-SWITCH-MIB::wrsPortStatusSfpVN.2 = STRING: Axcen Photonics
WR-SWITCH-MIB::wrsPortStatusSfpPN.1 = STRING: AXGE-3454-0531
WR-SWITCH-MIB::wrsPortStatusSfpPN.2 = STRING: AXGE-3454-0531
WR-SWITCH-MIB::wrsPstatsHCPortName.1 = STRING: wri1
WR-SWITCH-MIB::wrsPstatsHCPortName.2 = STRING: wri2
[...]
WR-SWITCH-MIB::wrsPstatsHCTXFrames.1 = Counter64: 232
WR-SWITCH-MIB::wrsPstatsHCTXFrames.2 = Counter64: 543
[...]
WR-SWITCH-MIB::wrsPstatsHCRXFrames.1 = Counter64: 255
WR-SWITCH-MIB::wrsPstatsHCRXFrames.2 = Counter64: 544

Another example is to print all objects exported by the switch.
@smallexample
snmpwalk -c public -v 2c wrs -m all \
        -M $WRS_OUTPUT_DIR/build/buildroot-2016.02/output/build/netsnmp-5.7.3/mibs/\
        :$WR_SWITCH_SW/userspace/snmpd/ \
@c ==========================================================================
@node show-pstats
@section show-pstats

To visualize all port statistics in a single window, this package
includes the simple tool @t{userspace/snmpd/show-pstats}.  It is
a Tk script, so you need to install @t{tk8.5} or any other version.

The script receives one or more host names (or IP addresses) on the command
line. They must refer to a switch (or switches) or the program fails like this:

@smallexample
   laptopo% ./show-pstats morgana
   Error in snmpwalk for host morgana
   No log handling enabled - using stderr logging
   .1.3.6.1.4.1.96.100.2.1.: Unknown Object Identifier (Sub-id not found: enterprises -> )
@end smallexample

If everything goes well, you'll get a window like the following one:

@center @image{show-pstats, 10cm,, show-pstats}

Command @t{snmptable} can also be used to get similar results:

@smallexample
snmptable -Cw 80 -c public -v 2c 192.168.1.10 -m all \
-M $WRS_OUTPUT_DIR/build/buildroot-2016.02/output/build/netsnmp-5.7.3/mibs/\
:userspace/snmpd/ WR-SWITCH-MIB::wrsPstatsHCTable
@end smallexample
Output is in text form and looks like:
@smallexample
SNMP table: WR-SWITCH-MIB::wrsPstatsHCTable

 wrsPstatsHCPortName wrsPstatsHCTXUnderrun wrsPstatsHCRXOverrun
                wri1                     0                    0
                wri2                     0                    0
                wri3                     0                    0
                wri4                     0                    0
                wri5                     0                    0
                wri6                     0                    0
                wri7                     0                    0
                wri8                     0                    0
                wri9                     0                    0
               wri10                     0                    0
               wri11                     0                    0
               wri12                     0                    0
               wri13                     0                    0
               wri14                     0                    0
               wri15                     0                    0
               wri16                     0                    0
               wri17                     0                    0
               wri18                     0                    0

SNMP table WR-SWITCH-MIB::wrsPstatsHCTable, part 2

 wrsPstatsHCRXInvalidCode wrsPstatsHCRXSyncLost wrsPstatsHCRXPauseFrames
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0
                        0                     0                        0

(...)
@end smallexample
Unfortunately output due to the number of counters is very wide. Number of 
characters per line can be limited by switch @t{Cw}, in example was set to 80.

@c ##########################################################################
@node Bugs and Troubleshooting
@appendix Bugs and Troubleshooting

Even if the package is already released and used in production,
some details can be
suboptimal, while some procedures may be tricky and need more explanation.
We are collecting all those issues in our project pages. Please visit:
@itemize
   @item Frequently Asked Questions: @url{http://www.ohwr.org/project/white-rabbit/wiki/FAQswitch}
   @item Issues for WR Switch SW project: @url{http://www.ohwr.org/project/wr-switch-sw/issues}
   @item Issues for WR Switch HDL project: @url{http://www.ohwr.org/project/wr-switch-hdl/issues}
@end itemize
If you have any problem with this firmware and you don't find help in the above links,
feel free to reach us on the @i{white-rabbit-dev} mailing list.

@c ==========================================================================
@node Dumping WRS state (wrs_dump)
@section Dumping WRS state (wrs_dump)

The @t{wrs_dump.sh} can dump the current state of a switch. Its use can be
helpful when reporting a bug or saving a switch's state for later analysis.

The tool can be found in WRS software repository (or accessed directly via
weblink @url{https://ohwr.org/project/wr-switch-sw/blob/master/userspace/host_tools/wrs_dump.sh}).

The @t{wrs_dump.sh} is independent from the WR software, it can be used on
different versions of firmware.
It can be run from a host computer or even WR switch
(however, @t{wrs_dump.sh} is not included in the firmware).
It connects from a host machine via @t{ssh} to a switch and gets the following
information in the order:
@itemize
  @item firmware version information (output of @t{wrs_version})
  @item logged users and uptime (output of @t{w} command)
  @item process list (output of @t{ps} command)
  @item dump of shared memory of WR specific daemons (output of @t{wrs_dump_shmem})
  @item detailed port statistics (output of @t{wrs_pstats})
  @item timing status and configuration (output of @t{wr_mon})
  @item local disk usage (output of @t{df})
  @item information about free memory (output of @t{free})
  @item detailed information about memory usage (output of @t{/proc/meminfo})
  @item information about network interfaces (output of @t{ifconfig})
  @item traffic on working WR ports; using @t{tcpdump} of up ports (or on
        specified ports depending on the parameter)
  @item output of PPSI's verbose messages (if selected by the parameter);
        it may affect synchronization (not seen in practice)
  @item output of @t{dmesg}
  @item information about VLAN configuration (output of @t{wrs_vlans --list}
        and  @t{wrs_vlans --plist})
  @item information about routing (switching) rules (output of @t{rtu_stat})
  @item SFP information (output of @t{wrs_sfp_dump -L -d -x})
  @item copy of dot-config
  @item copy of shared memory files of WR specific daemons
  @item copy content of /tmp
@end itemize
During the run of this tool many parameters could have changed their values.
Such information might be  important during further investigation. For this
reason the tool reads once more some information:
@itemize
  @item process list (output of @t{ps} command)
  @item dump of shared memory of WR specific daemons (output of @t{wrs_dump_shmem})
  @item detailed port statistics (output of @t{wrs_pstats})
  @item timing status and configuration (output of @t{wr_mon})
  @item local disk usage (output of @t{df})
  @item information about free memory (output of @t{free})
  @item detailed information about memory usage (output of @t{/proc/meminfo})
  @item information about network interfaces (output of @t{ifconfig})
@end itemize

By default, the gathered information is stored in the directory
@t{wrs_dump-<hostname>-<date>}. If needed the output directory can be changed
with @t{--output} parameter.
It is possible to define the list of ports that @t{tcpdump} shall be run on.
The verbosity of PPSi can be set to the predefined value
(@t{--ppsi-verbose <verbose_mode>}) or set to dump all messages
(@t{--ppsi-verbose-all}) for 60 seconds.

If for some reason it is not possible to use password or ssh-keys for
authentication to login to the switch, the user can store the password in
host's @t{WRS_PSWD} environment variable.
The content of this environment variable will be passed to the @t{sshpass}
command instead.

Example run of @t{wrs_dump.sh}:
@smallexample
$ ./wrs_dump.sh root@@wrs
Example printout:
root@@wrs ppsi_verbose_mode=
Open ssh connection...
Provide password
Password:
ssh connection established
Store data in the directory wrs_dump-wrs-2022-08-28_04-46-52
Get version... Done
Get w (logged users and uptime)... Done
Get process list... Done
Get output of wrs_dump_shmem... Done
Get output of wrs_pstats... Done
Get output of wr_mon... Done
Get output of df... Done
Get output of free... Done
Get output of /proc/meminfo... Done
Get output of ifconfig... Done
Get tcpdump for up ports: wri1 wri4 wri15
Get output of tcpdump wri1... Done
Get output of tcpdump wri4... Done
Get output of tcpdump wri15... Done
Get output of dmesg... Done
Get output of wrs_vlans --list... Done
Get output of wrs_vlans --plist... Done
Get output of rtu_stat... Done
Get output of wrs_sfp_dump -L -d -x... Done
Copy dot-config... Done
Copy shmem... Done
Copy /tmp... Done
Get again process list... Done
Get again output of wrs_dump_shmem... Done
Get again output of wrs_pstats... Done
Get again output of wr_mon... Done
Get again output of df... Done
Get again output of free... Done
Get again output of /proc/meminfo... Done
Get again output of ifconfig... Done
Closing ssh connection... Done
@end smallexample

@c ##########################################################################
@bye


@c  LocalWords:  gnudd titlepage iftex texinfo CERN timestamping smallexample
@c  LocalWords:  LocalWords ietf timestamp misc timestamps ttstamp onestamp
@c  LocalWords:  Tomasz Wlostowski buildroot distclean defconfig wrswitch REPO
@c  LocalWords:  menuconfig config dataflash whiterabbit stdout stderr svnsync
@c  LocalWords:  filesystem diff ohwr http mkdir linux rubini itemize PTPd VHDL
@c  LocalWords:  noposix ptpd userspace libwr DataFlash NAND barebox FPGA
@c  LocalWords:  Atmel Kconfig minicom tinyserial ttyUSB bootloader logfile
Alessandro Rubini's avatar
Alessandro Rubini committed
@c  LocalWords:  nandflash gateware TFTP init wrboot wiki LEDs DHCP
@c  LocalWords:  SNMP hwinfo pathname CONFIG filename Busybox Barebox
@c  LocalWords:  rsyslog PARAMS subdirectory dhcp nand VLAN vlans
@c  LocalWords:  auxclk bitstream