4453107633
Denote that the new switch generation is supported, detail its pin strapping options (with differences compared to SJA1105) and explain how MDIO access to the internal 100base-T1 and 100base-TX PHYs is performed. Signed-off-by: Vladimir Oltean <vladimir.oltean@nxp.com> Signed-off-by: David S. Miller <davem@davemloft.net>
635 lines
29 KiB
ReStructuredText
635 lines
29 KiB
ReStructuredText
=========================
|
|
NXP SJA1105 switch driver
|
|
=========================
|
|
|
|
Overview
|
|
========
|
|
|
|
The NXP SJA1105 is a family of 10 SPI-managed automotive switches:
|
|
|
|
- SJA1105E: First generation, no TTEthernet
|
|
- SJA1105T: First generation, TTEthernet
|
|
- SJA1105P: Second generation, no TTEthernet, no SGMII
|
|
- SJA1105Q: Second generation, TTEthernet, no SGMII
|
|
- SJA1105R: Second generation, no TTEthernet, SGMII
|
|
- SJA1105S: Second generation, TTEthernet, SGMII
|
|
- SJA1110A: Third generation, TTEthernet, SGMII, integrated 100base-T1 and
|
|
100base-TX PHYs
|
|
- SJA1110B: Third generation, TTEthernet, SGMII, 100base-T1, 100base-TX
|
|
- SJA1110C: Third generation, TTEthernet, SGMII, 100base-T1, 100base-TX
|
|
- SJA1110D: Third generation, TTEthernet, SGMII, 100base-T1
|
|
|
|
Being automotive parts, their configuration interface is geared towards
|
|
set-and-forget use, with minimal dynamic interaction at runtime. They
|
|
require a static configuration to be composed by software and packed
|
|
with CRC and table headers, and sent over SPI.
|
|
|
|
The static configuration is composed of several configuration tables. Each
|
|
table takes a number of entries. Some configuration tables can be (partially)
|
|
reconfigured at runtime, some not. Some tables are mandatory, some not:
|
|
|
|
============================= ================== =============================
|
|
Table Mandatory Reconfigurable
|
|
============================= ================== =============================
|
|
Schedule no no
|
|
Schedule entry points if Scheduling no
|
|
VL Lookup no no
|
|
VL Policing if VL Lookup no
|
|
VL Forwarding if VL Lookup no
|
|
L2 Lookup no no
|
|
L2 Policing yes no
|
|
VLAN Lookup yes yes
|
|
L2 Forwarding yes partially (fully on P/Q/R/S)
|
|
MAC Config yes partially (fully on P/Q/R/S)
|
|
Schedule Params if Scheduling no
|
|
Schedule Entry Points Params if Scheduling no
|
|
VL Forwarding Params if VL Forwarding no
|
|
L2 Lookup Params no partially (fully on P/Q/R/S)
|
|
L2 Forwarding Params yes no
|
|
Clock Sync Params no no
|
|
AVB Params no no
|
|
General Params yes partially
|
|
Retagging no yes
|
|
xMII Params yes no
|
|
SGMII no yes
|
|
============================= ================== =============================
|
|
|
|
|
|
Also the configuration is write-only (software cannot read it back from the
|
|
switch except for very few exceptions).
|
|
|
|
The driver creates a static configuration at probe time, and keeps it at
|
|
all times in memory, as a shadow for the hardware state. When required to
|
|
change a hardware setting, the static configuration is also updated.
|
|
If that changed setting can be transmitted to the switch through the dynamic
|
|
reconfiguration interface, it is; otherwise the switch is reset and
|
|
reprogrammed with the updated static configuration.
|
|
|
|
Traffic support
|
|
===============
|
|
|
|
The switches do not have hardware support for DSA tags, except for "slow
|
|
protocols" for switch control as STP and PTP. For these, the switches have two
|
|
programmable filters for link-local destination MACs.
|
|
These are used to trap BPDUs and PTP traffic to the master netdevice, and are
|
|
further used to support STP and 1588 ordinary clock/boundary clock
|
|
functionality. For frames trapped to the CPU, source port and switch ID
|
|
information is encoded by the hardware into the frames.
|
|
|
|
But by leveraging ``CONFIG_NET_DSA_TAG_8021Q`` (a software-defined DSA tagging
|
|
format based on VLANs), general-purpose traffic termination through the network
|
|
stack can be supported under certain circumstances.
|
|
|
|
Depending on VLAN awareness state, the following operating modes are possible
|
|
with the switch:
|
|
|
|
- Mode 1 (VLAN-unaware): a port is in this mode when it is used as a standalone
|
|
net device, or when it is enslaved to a bridge with ``vlan_filtering=0``.
|
|
- Mode 2 (fully VLAN-aware): a port is in this mode when it is enslaved to a
|
|
bridge with ``vlan_filtering=1``. Access to the entire VLAN range is given to
|
|
the user through ``bridge vlan`` commands, but general-purpose (anything
|
|
other than STP, PTP etc) traffic termination is not possible through the
|
|
switch net devices. The other packets can be still by user space processed
|
|
through the DSA master interface (similar to ``DSA_TAG_PROTO_NONE``).
|
|
- Mode 3 (best-effort VLAN-aware): a port is in this mode when enslaved to a
|
|
bridge with ``vlan_filtering=1``, and the devlink property of its parent
|
|
switch named ``best_effort_vlan_filtering`` is set to ``true``. When
|
|
configured like this, the range of usable VIDs is reduced (0 to 1023 and 3072
|
|
to 4094), so is the number of usable VIDs (maximum of 7 non-pvid VLANs per
|
|
port*), and shared VLAN learning is performed (FDB lookup is done only by
|
|
DMAC, not also by VID).
|
|
|
|
To summarize, in each mode, the following types of traffic are supported over
|
|
the switch net devices:
|
|
|
|
+-------------+-----------+--------------+------------+
|
|
| | Mode 1 | Mode 2 | Mode 3 |
|
|
+=============+===========+==============+============+
|
|
| Regular | Yes | No | Yes |
|
|
| traffic | | (use master) | |
|
|
+-------------+-----------+--------------+------------+
|
|
| Management | Yes | Yes | Yes |
|
|
| traffic | | | |
|
|
| (BPDU, PTP) | | | |
|
|
+-------------+-----------+--------------+------------+
|
|
|
|
To configure the switch to operate in Mode 3, the following steps can be
|
|
followed::
|
|
|
|
ip link add dev br0 type bridge
|
|
# swp2 operates in Mode 1 now
|
|
ip link set dev swp2 master br0
|
|
# swp2 temporarily moves to Mode 2
|
|
ip link set dev br0 type bridge vlan_filtering 1
|
|
[ 61.204770] sja1105 spi0.1: Reset switch and programmed static config. Reason: VLAN filtering
|
|
[ 61.239944] sja1105 spi0.1: Disabled switch tagging
|
|
# swp3 now operates in Mode 3
|
|
devlink dev param set spi/spi0.1 name best_effort_vlan_filtering value true cmode runtime
|
|
[ 64.682927] sja1105 spi0.1: Reset switch and programmed static config. Reason: VLAN filtering
|
|
[ 64.711925] sja1105 spi0.1: Enabled switch tagging
|
|
# Cannot use VLANs in range 1024-3071 while in Mode 3.
|
|
bridge vlan add dev swp2 vid 1025 untagged pvid
|
|
RTNETLINK answers: Operation not permitted
|
|
bridge vlan add dev swp2 vid 100
|
|
bridge vlan add dev swp2 vid 101 untagged
|
|
bridge vlan
|
|
port vlan ids
|
|
swp5 1 PVID Egress Untagged
|
|
|
|
swp2 1 PVID Egress Untagged
|
|
100
|
|
101 Egress Untagged
|
|
|
|
swp3 1 PVID Egress Untagged
|
|
|
|
swp4 1 PVID Egress Untagged
|
|
|
|
br0 1 PVID Egress Untagged
|
|
bridge vlan add dev swp2 vid 102
|
|
bridge vlan add dev swp2 vid 103
|
|
bridge vlan add dev swp2 vid 104
|
|
bridge vlan add dev swp2 vid 105
|
|
bridge vlan add dev swp2 vid 106
|
|
bridge vlan add dev swp2 vid 107
|
|
# Cannot use mode than 7 VLANs per port while in Mode 3.
|
|
[ 3885.216832] sja1105 spi0.1: No more free subvlans
|
|
|
|
\* "maximum of 7 non-pvid VLANs per port": Decoding VLAN-tagged packets on the
|
|
CPU in mode 3 is possible through VLAN retagging of packets that go from the
|
|
switch to the CPU. In cross-chip topologies, the port that goes to the CPU
|
|
might also go to other switches. In that case, those other switches will see
|
|
only a retagged packet (which only has meaning for the CPU). So if they are
|
|
interested in this VLAN, they need to apply retagging in the reverse direction,
|
|
to recover the original value from it. This consumes extra hardware resources
|
|
for this switch. There is a maximum of 32 entries in the Retagging Table of
|
|
each switch device.
|
|
|
|
As an example, consider this cross-chip topology::
|
|
|
|
+-------------------------------------------------+
|
|
| Host SoC |
|
|
| +-------------------------+ |
|
|
| | DSA master for embedded | |
|
|
| | switch (non-sja1105) | |
|
|
| +--------+-------------------------+--------+ |
|
|
| | embedded L2 switch | |
|
|
| | | |
|
|
| | +--------------+ +--------------+ | |
|
|
| | |DSA master for| |DSA master for| | |
|
|
| | | SJA1105 1 | | SJA1105 2 | | |
|
|
+--+---+--------------+-----+--------------+---+--+
|
|
|
|
+-----------------------+ +-----------------------+
|
|
| SJA1105 switch 1 | | SJA1105 switch 2 |
|
|
+-----+-----+-----+-----+ +-----+-----+-----+-----+
|
|
|sw1p0|sw1p1|sw1p2|sw1p3| |sw2p0|sw2p1|sw2p2|sw2p3|
|
|
+-----+-----+-----+-----+ +-----+-----+-----+-----+
|
|
|
|
To reach the CPU, SJA1105 switch 1 (spi/spi2.1) uses the same port as is uses
|
|
to reach SJA1105 switch 2 (spi/spi2.2), which would be port 4 (not drawn).
|
|
Similarly for SJA1105 switch 2.
|
|
|
|
Also consider the following commands, that add VLAN 100 to every sja1105 user
|
|
port::
|
|
|
|
devlink dev param set spi/spi2.1 name best_effort_vlan_filtering value true cmode runtime
|
|
devlink dev param set spi/spi2.2 name best_effort_vlan_filtering value true cmode runtime
|
|
ip link add dev br0 type bridge
|
|
for port in sw1p0 sw1p1 sw1p2 sw1p3 \
|
|
sw2p0 sw2p1 sw2p2 sw2p3; do
|
|
ip link set dev $port master br0
|
|
done
|
|
ip link set dev br0 type bridge vlan_filtering 1
|
|
for port in sw1p0 sw1p1 sw1p2 sw1p3 \
|
|
sw2p0 sw2p1 sw2p2; do
|
|
bridge vlan add dev $port vid 100
|
|
done
|
|
ip link add link br0 name br0.100 type vlan id 100 && ip link set dev br0.100 up
|
|
ip addr add 192.168.100.3/24 dev br0.100
|
|
bridge vlan add dev br0 vid 100 self
|
|
|
|
bridge vlan
|
|
port vlan ids
|
|
sw1p0 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw1p1 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw1p2 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw1p3 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw2p0 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw2p1 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw2p2 1 PVID Egress Untagged
|
|
100
|
|
|
|
sw2p3 1 PVID Egress Untagged
|
|
|
|
br0 1 PVID Egress Untagged
|
|
100
|
|
|
|
SJA1105 switch 1 consumes 1 retagging entry for each VLAN on each user port
|
|
towards the CPU. It also consumes 1 retagging entry for each non-pvid VLAN that
|
|
it is also interested in, which is configured on any port of any neighbor
|
|
switch.
|
|
|
|
In this case, SJA1105 switch 1 consumes a total of 11 retagging entries, as
|
|
follows:
|
|
|
|
- 8 retagging entries for VLANs 1 and 100 installed on its user ports
|
|
(``sw1p0`` - ``sw1p3``)
|
|
- 3 retagging entries for VLAN 100 installed on the user ports of SJA1105
|
|
switch 2 (``sw2p0`` - ``sw2p2``), because it also has ports that are
|
|
interested in it. The VLAN 1 is a pvid on SJA1105 switch 2 and does not need
|
|
reverse retagging.
|
|
|
|
SJA1105 switch 2 also consumes 11 retagging entries, but organized as follows:
|
|
|
|
- 7 retagging entries for the bridge VLANs on its user ports (``sw2p0`` -
|
|
``sw2p3``).
|
|
- 4 retagging entries for VLAN 100 installed on the user ports of SJA1105
|
|
switch 1 (``sw1p0`` - ``sw1p3``).
|
|
|
|
Switching features
|
|
==================
|
|
|
|
The driver supports the configuration of L2 forwarding rules in hardware for
|
|
port bridging. The forwarding, broadcast and flooding domain between ports can
|
|
be restricted through two methods: either at the L2 forwarding level (isolate
|
|
one bridge's ports from another's) or at the VLAN port membership level
|
|
(isolate ports within the same bridge). The final forwarding decision taken by
|
|
the hardware is a logical AND of these two sets of rules.
|
|
|
|
The hardware tags all traffic internally with a port-based VLAN (pvid), or it
|
|
decodes the VLAN information from the 802.1Q tag. Advanced VLAN classification
|
|
is not possible. Once attributed a VLAN tag, frames are checked against the
|
|
port's membership rules and dropped at ingress if they don't match any VLAN.
|
|
This behavior is available when switch ports are enslaved to a bridge with
|
|
``vlan_filtering 1``.
|
|
|
|
Normally the hardware is not configurable with respect to VLAN awareness, but
|
|
by changing what TPID the switch searches 802.1Q tags for, the semantics of a
|
|
bridge with ``vlan_filtering 0`` can be kept (accept all traffic, tagged or
|
|
untagged), and therefore this mode is also supported.
|
|
|
|
Segregating the switch ports in multiple bridges is supported (e.g. 2 + 2), but
|
|
all bridges should have the same level of VLAN awareness (either both have
|
|
``vlan_filtering`` 0, or both 1). Also an inevitable limitation of the fact
|
|
that VLAN awareness is global at the switch level is that once a bridge with
|
|
``vlan_filtering`` enslaves at least one switch port, the other un-bridged
|
|
ports are no longer available for standalone traffic termination.
|
|
|
|
Topology and loop detection through STP is supported.
|
|
|
|
L2 FDB manipulation (add/delete/dump) is currently possible for the first
|
|
generation devices. Aging time of FDB entries, as well as enabling fully static
|
|
management (no address learning and no flooding of unknown traffic) is not yet
|
|
configurable in the driver.
|
|
|
|
A special comment about bridging with other netdevices (illustrated with an
|
|
example):
|
|
|
|
A board has eth0, eth1, swp0@eth1, swp1@eth1, swp2@eth1, swp3@eth1.
|
|
The switch ports (swp0-3) are under br0.
|
|
It is desired that eth0 is turned into another switched port that communicates
|
|
with swp0-3.
|
|
|
|
If br0 has vlan_filtering 0, then eth0 can simply be added to br0 with the
|
|
intended results.
|
|
If br0 has vlan_filtering 1, then a new br1 interface needs to be created that
|
|
enslaves eth0 and eth1 (the DSA master of the switch ports). This is because in
|
|
this mode, the switch ports beneath br0 are not capable of regular traffic, and
|
|
are only used as a conduit for switchdev operations.
|
|
|
|
Offloads
|
|
========
|
|
|
|
Time-aware scheduling
|
|
---------------------
|
|
|
|
The switch supports a variation of the enhancements for scheduled traffic
|
|
specified in IEEE 802.1Q-2018 (formerly 802.1Qbv). This means it can be used to
|
|
ensure deterministic latency for priority traffic that is sent in-band with its
|
|
gate-open event in the network schedule.
|
|
|
|
This capability can be managed through the tc-taprio offload ('flags 2'). The
|
|
difference compared to the software implementation of taprio is that the latter
|
|
would only be able to shape traffic originated from the CPU, but not
|
|
autonomously forwarded flows.
|
|
|
|
The device has 8 traffic classes, and maps incoming frames to one of them based
|
|
on the VLAN PCP bits (if no VLAN is present, the port-based default is used).
|
|
As described in the previous sections, depending on the value of
|
|
``vlan_filtering``, the EtherType recognized by the switch as being VLAN can
|
|
either be the typical 0x8100 or a custom value used internally by the driver
|
|
for tagging. Therefore, the switch ignores the VLAN PCP if used in standalone
|
|
or bridge mode with ``vlan_filtering=0``, as it will not recognize the 0x8100
|
|
EtherType. In these modes, injecting into a particular TX queue can only be
|
|
done by the DSA net devices, which populate the PCP field of the tagging header
|
|
on egress. Using ``vlan_filtering=1``, the behavior is the other way around:
|
|
offloaded flows can be steered to TX queues based on the VLAN PCP, but the DSA
|
|
net devices are no longer able to do that. To inject frames into a hardware TX
|
|
queue with VLAN awareness active, it is necessary to create a VLAN
|
|
sub-interface on the DSA master port, and send normal (0x8100) VLAN-tagged
|
|
towards the switch, with the VLAN PCP bits set appropriately.
|
|
|
|
Management traffic (having DMAC 01-80-C2-xx-xx-xx or 01-19-1B-xx-xx-xx) is the
|
|
notable exception: the switch always treats it with a fixed priority and
|
|
disregards any VLAN PCP bits even if present. The traffic class for management
|
|
traffic has a value of 7 (highest priority) at the moment, which is not
|
|
configurable in the driver.
|
|
|
|
Below is an example of configuring a 500 us cyclic schedule on egress port
|
|
``swp5``. The traffic class gate for management traffic (7) is open for 100 us,
|
|
and the gates for all other traffic classes are open for 400 us::
|
|
|
|
#!/bin/bash
|
|
|
|
set -e -u -o pipefail
|
|
|
|
NSEC_PER_SEC="1000000000"
|
|
|
|
gatemask() {
|
|
local tc_list="$1"
|
|
local mask=0
|
|
|
|
for tc in ${tc_list}; do
|
|
mask=$((${mask} | (1 << ${tc})))
|
|
done
|
|
|
|
printf "%02x" ${mask}
|
|
}
|
|
|
|
if ! systemctl is-active --quiet ptp4l; then
|
|
echo "Please start the ptp4l service"
|
|
exit
|
|
fi
|
|
|
|
now=$(phc_ctl /dev/ptp1 get | gawk '/clock time is/ { print $5; }')
|
|
# Phase-align the base time to the start of the next second.
|
|
sec=$(echo "${now}" | gawk -F. '{ print $1; }')
|
|
base_time="$(((${sec} + 1) * ${NSEC_PER_SEC}))"
|
|
|
|
tc qdisc add dev swp5 parent root handle 100 taprio \
|
|
num_tc 8 \
|
|
map 0 1 2 3 5 6 7 \
|
|
queues 1@0 1@1 1@2 1@3 1@4 1@5 1@6 1@7 \
|
|
base-time ${base_time} \
|
|
sched-entry S $(gatemask 7) 100000 \
|
|
sched-entry S $(gatemask "0 1 2 3 4 5 6") 400000 \
|
|
flags 2
|
|
|
|
It is possible to apply the tc-taprio offload on multiple egress ports. There
|
|
are hardware restrictions related to the fact that no gate event may trigger
|
|
simultaneously on two ports. The driver checks the consistency of the schedules
|
|
against this restriction and errors out when appropriate. Schedule analysis is
|
|
needed to avoid this, which is outside the scope of the document.
|
|
|
|
Routing actions (redirect, trap, drop)
|
|
--------------------------------------
|
|
|
|
The switch is able to offload flow-based redirection of packets to a set of
|
|
destination ports specified by the user. Internally, this is implemented by
|
|
making use of Virtual Links, a TTEthernet concept.
|
|
|
|
The driver supports 2 types of keys for Virtual Links:
|
|
|
|
- VLAN-aware virtual links: these match on destination MAC address, VLAN ID and
|
|
VLAN PCP.
|
|
- VLAN-unaware virtual links: these match on destination MAC address only.
|
|
|
|
The VLAN awareness state of the bridge (vlan_filtering) cannot be changed while
|
|
there are virtual link rules installed.
|
|
|
|
Composing multiple actions inside the same rule is supported. When only routing
|
|
actions are requested, the driver creates a "non-critical" virtual link. When
|
|
the action list also contains tc-gate (more details below), the virtual link
|
|
becomes "time-critical" (draws frame buffers from a reserved memory partition,
|
|
etc).
|
|
|
|
The 3 routing actions that are supported are "trap", "drop" and "redirect".
|
|
|
|
Example 1: send frames received on swp2 with a DA of 42:be:24:9b:76:20 to the
|
|
CPU and to swp3. This type of key (DA only) when the port's VLAN awareness
|
|
state is off::
|
|
|
|
tc qdisc add dev swp2 clsact
|
|
tc filter add dev swp2 ingress flower skip_sw dst_mac 42:be:24:9b:76:20 \
|
|
action mirred egress redirect dev swp3 \
|
|
action trap
|
|
|
|
Example 2: drop frames received on swp2 with a DA of 42:be:24:9b:76:20, a VID
|
|
of 100 and a PCP of 0::
|
|
|
|
tc filter add dev swp2 ingress protocol 802.1Q flower skip_sw \
|
|
dst_mac 42:be:24:9b:76:20 vlan_id 100 vlan_prio 0 action drop
|
|
|
|
Time-based ingress policing
|
|
---------------------------
|
|
|
|
The TTEthernet hardware abilities of the switch can be constrained to act
|
|
similarly to the Per-Stream Filtering and Policing (PSFP) clause specified in
|
|
IEEE 802.1Q-2018 (formerly 802.1Qci). This means it can be used to perform
|
|
tight timing-based admission control for up to 1024 flows (identified by a
|
|
tuple composed of destination MAC address, VLAN ID and VLAN PCP). Packets which
|
|
are received outside their expected reception window are dropped.
|
|
|
|
This capability can be managed through the offload of the tc-gate action. As
|
|
routing actions are intrinsic to virtual links in TTEthernet (which performs
|
|
explicit routing of time-critical traffic and does not leave that in the hands
|
|
of the FDB, flooding etc), the tc-gate action may never appear alone when
|
|
asking sja1105 to offload it. One (or more) redirect or trap actions must also
|
|
follow along.
|
|
|
|
Example: create a tc-taprio schedule that is phase-aligned with a tc-gate
|
|
schedule (the clocks must be synchronized by a 1588 application stack, which is
|
|
outside the scope of this document). No packet delivered by the sender will be
|
|
dropped. Note that the reception window is larger than the transmission window
|
|
(and much more so, in this example) to compensate for the packet propagation
|
|
delay of the link (which can be determined by the 1588 application stack).
|
|
|
|
Receiver (sja1105)::
|
|
|
|
tc qdisc add dev swp2 clsact
|
|
now=$(phc_ctl /dev/ptp1 get | awk '/clock time is/ {print $5}') && \
|
|
sec=$(echo $now | awk -F. '{print $1}') && \
|
|
base_time="$(((sec + 2) * 1000000000))" && \
|
|
echo "base time ${base_time}"
|
|
tc filter add dev swp2 ingress flower skip_sw \
|
|
dst_mac 42:be:24:9b:76:20 \
|
|
action gate base-time ${base_time} \
|
|
sched-entry OPEN 60000 -1 -1 \
|
|
sched-entry CLOSE 40000 -1 -1 \
|
|
action trap
|
|
|
|
Sender::
|
|
|
|
now=$(phc_ctl /dev/ptp0 get | awk '/clock time is/ {print $5}') && \
|
|
sec=$(echo $now | awk -F. '{print $1}') && \
|
|
base_time="$(((sec + 2) * 1000000000))" && \
|
|
echo "base time ${base_time}"
|
|
tc qdisc add dev eno0 parent root taprio \
|
|
num_tc 8 \
|
|
map 0 1 2 3 4 5 6 7 \
|
|
queues 1@0 1@1 1@2 1@3 1@4 1@5 1@6 1@7 \
|
|
base-time ${base_time} \
|
|
sched-entry S 01 50000 \
|
|
sched-entry S 00 50000 \
|
|
flags 2
|
|
|
|
The engine used to schedule the ingress gate operations is the same that the
|
|
one used for the tc-taprio offload. Therefore, the restrictions regarding the
|
|
fact that no two gate actions (either tc-gate or tc-taprio gates) may fire at
|
|
the same time (during the same 200 ns slot) still apply.
|
|
|
|
To come in handy, it is possible to share time-triggered virtual links across
|
|
more than 1 ingress port, via flow blocks. In this case, the restriction of
|
|
firing at the same time does not apply because there is a single schedule in
|
|
the system, that of the shared virtual link::
|
|
|
|
tc qdisc add dev swp2 ingress_block 1 clsact
|
|
tc qdisc add dev swp3 ingress_block 1 clsact
|
|
tc filter add block 1 flower skip_sw dst_mac 42:be:24:9b:76:20 \
|
|
action gate index 2 \
|
|
base-time 0 \
|
|
sched-entry OPEN 50000000 -1 -1 \
|
|
sched-entry CLOSE 50000000 -1 -1 \
|
|
action trap
|
|
|
|
Hardware statistics for each flow are also available ("pkts" counts the number
|
|
of dropped frames, which is a sum of frames dropped due to timing violations,
|
|
lack of destination ports and MTU enforcement checks). Byte-level counters are
|
|
not available.
|
|
|
|
Device Tree bindings and board design
|
|
=====================================
|
|
|
|
This section references ``Documentation/devicetree/bindings/net/dsa/sja1105.txt``
|
|
and aims to showcase some potential switch caveats.
|
|
|
|
RMII PHY role and out-of-band signaling
|
|
---------------------------------------
|
|
|
|
In the RMII spec, the 50 MHz clock signals are either driven by the MAC or by
|
|
an external oscillator (but not by the PHY).
|
|
But the spec is rather loose and devices go outside it in several ways.
|
|
Some PHYs go against the spec and may provide an output pin where they source
|
|
the 50 MHz clock themselves, in an attempt to be helpful.
|
|
On the other hand, the SJA1105 is only binary configurable - when in the RMII
|
|
MAC role it will also attempt to drive the clock signal. To prevent this from
|
|
happening it must be put in RMII PHY role.
|
|
But doing so has some unintended consequences.
|
|
In the RMII spec, the PHY can transmit extra out-of-band signals via RXD[1:0].
|
|
These are practically some extra code words (/J/ and /K/) sent prior to the
|
|
preamble of each frame. The MAC does not have this out-of-band signaling
|
|
mechanism defined by the RMII spec.
|
|
So when the SJA1105 port is put in PHY role to avoid having 2 drivers on the
|
|
clock signal, inevitably an RMII PHY-to-PHY connection is created. The SJA1105
|
|
emulates a PHY interface fully and generates the /J/ and /K/ symbols prior to
|
|
frame preambles, which the real PHY is not expected to understand. So the PHY
|
|
simply encodes the extra symbols received from the SJA1105-as-PHY onto the
|
|
100Base-Tx wire.
|
|
On the other side of the wire, some link partners might discard these extra
|
|
symbols, while others might choke on them and discard the entire Ethernet
|
|
frames that follow along. This looks like packet loss with some link partners
|
|
but not with others.
|
|
The take-away is that in RMII mode, the SJA1105 must be let to drive the
|
|
reference clock if connected to a PHY.
|
|
|
|
RGMII fixed-link and internal delays
|
|
------------------------------------
|
|
|
|
As mentioned in the bindings document, the second generation of devices has
|
|
tunable delay lines as part of the MAC, which can be used to establish the
|
|
correct RGMII timing budget.
|
|
When powered up, these can shift the Rx and Tx clocks with a phase difference
|
|
between 73.8 and 101.7 degrees.
|
|
The catch is that the delay lines need to lock onto a clock signal with a
|
|
stable frequency. This means that there must be at least 2 microseconds of
|
|
silence between the clock at the old vs at the new frequency. Otherwise the
|
|
lock is lost and the delay lines must be reset (powered down and back up).
|
|
In RGMII the clock frequency changes with link speed (125 MHz at 1000 Mbps, 25
|
|
MHz at 100 Mbps and 2.5 MHz at 10 Mbps), and link speed might change during the
|
|
AN process.
|
|
In the situation where the switch port is connected through an RGMII fixed-link
|
|
to a link partner whose link state life cycle is outside the control of Linux
|
|
(such as a different SoC), then the delay lines would remain unlocked (and
|
|
inactive) until there is manual intervention (ifdown/ifup on the switch port).
|
|
The take-away is that in RGMII mode, the switch's internal delays are only
|
|
reliable if the link partner never changes link speeds, or if it does, it does
|
|
so in a way that is coordinated with the switch port (practically, both ends of
|
|
the fixed-link are under control of the same Linux system).
|
|
As to why would a fixed-link interface ever change link speeds: there are
|
|
Ethernet controllers out there which come out of reset in 100 Mbps mode, and
|
|
their driver inevitably needs to change the speed and clock frequency if it's
|
|
required to work at gigabit.
|
|
|
|
MDIO bus and PHY management
|
|
---------------------------
|
|
|
|
The SJA1105 does not have an MDIO bus and does not perform in-band AN either.
|
|
Therefore there is no link state notification coming from the switch device.
|
|
A board would need to hook up the PHYs connected to the switch to any other
|
|
MDIO bus available to Linux within the system (e.g. to the DSA master's MDIO
|
|
bus). Link state management then works by the driver manually keeping in sync
|
|
(over SPI commands) the MAC link speed with the settings negotiated by the PHY.
|
|
|
|
By comparison, the SJA1110 supports an MDIO slave access point over which its
|
|
internal 100base-T1 PHYs can be accessed from the host. This is, however, not
|
|
used by the driver, instead the internal 100base-T1 and 100base-TX PHYs are
|
|
accessed through SPI commands, modeled in Linux as virtual MDIO buses.
|
|
|
|
The microcontroller attached to the SJA1110 port 0 also has an MDIO controller
|
|
operating in master mode, however the driver does not support this either,
|
|
since the microcontroller gets disabled when the Linux driver operates.
|
|
Discrete PHYs connected to the switch ports should have their MDIO interface
|
|
attached to an MDIO controller from the host system and not to the switch,
|
|
similar to SJA1105.
|
|
|
|
Port compatibility matrix
|
|
-------------------------
|
|
|
|
The SJA1105 port compatibility matrix is:
|
|
|
|
===== ============== ============== ==============
|
|
Port SJA1105E/T SJA1105P/Q SJA1105R/S
|
|
===== ============== ============== ==============
|
|
0 xMII xMII xMII
|
|
1 xMII xMII xMII
|
|
2 xMII xMII xMII
|
|
3 xMII xMII xMII
|
|
4 xMII xMII SGMII
|
|
===== ============== ============== ==============
|
|
|
|
|
|
The SJA1110 port compatibility matrix is:
|
|
|
|
===== ============== ============== ============== ==============
|
|
Port SJA1110A SJA1110B SJA1110C SJA1110D
|
|
===== ============== ============== ============== ==============
|
|
0 RevMII (uC) RevMII (uC) RevMII (uC) RevMII (uC)
|
|
1 100base-TX 100base-TX 100base-TX
|
|
or SGMII SGMII
|
|
2 xMII xMII xMII xMII
|
|
or SGMII or SGMII
|
|
3 xMII xMII xMII
|
|
or SGMII or SGMII SGMII
|
|
or 2500base-X or 2500base-X or 2500base-X
|
|
4 SGMII SGMII SGMII SGMII
|
|
or 2500base-X or 2500base-X or 2500base-X or 2500base-X
|
|
5 100base-T1 100base-T1 100base-T1 100base-T1
|
|
6 100base-T1 100base-T1 100base-T1 100base-T1
|
|
7 100base-T1 100base-T1 100base-T1 100base-T1
|
|
8 100base-T1 100base-T1 n/a n/a
|
|
9 100base-T1 100base-T1 n/a n/a
|
|
10 100base-T1 n/a n/a n/a
|
|
===== ============== ============== ============== ==============
|