<?xml version="1.0" encoding="utf-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.8 (Ruby 2.6.10) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

]>

<?rfc comments="yes"?>

<rfc ipr="trust200902" docName="draft-eckert-detnet-tcqf-11" category="std" consensus="true" submissionType="IETF" tocDepth="5" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="detnet-tcqf">Deterministic Networking (DetNet) Data Plane - Tagged Cyclic Queuing and Forwarding (TCQF) for bounded latency with low jitter in large scale DetNets</title>

    <author initials="T." surname="Eckert" fullname="Toerless Eckert" role="editor">
      <organization>Futurewei Technologies USA</organization>
      <address>
        <postal>
          <street>2220 Central Expressway</street>
          <city>Santa Clara</city>
          <code>CA 95050</code>
          <country>USA</country>
        </postal>
        <email>tte@cs.fau.de</email>
      </address>
    </author>
    <author initials="Y." surname="Li" fullname="Yizhou Li" role="editor">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <city>Nanjing</city>
          <country>China</country>
        </postal>
        <email>liyizhou@huawei.com</email>
      </address>
    </author>
    <author initials="S." surname="Bryant" fullname="Stewart Bryant">
      <organization>University of Surrey ICS</organization>
      <address>
        <postal>
          <country>United Kingdom</country>
        </postal>
        <email>s.bryant@surrey.ac.uk</email>
      </address>
    </author>
    <author initials="A. G." surname="Malis" fullname="Andrew G. Malis">
      <organization>Malis Consulting</organization>
      <address>
        <postal>
          <country>USA</country>
        </postal>
        <email>agmalis@gmail.com</email>
      </address>
    </author>
    <author initials="J.-d." surname="Ryoo" fullname="Jeong-dong Ryoo">
      <organization>ETRI</organization>
      <address>
        <postal>
          <country>South Korea</country>
        </postal>
        <email>ryoo@etri.re.kr</email>
      </address>
    </author>
    <author initials="P." surname="Liu" fullname="Peng Liu">
      <organization>China Mobile</organization>
      <address>
        <postal>
          <country>China</country>
        </postal>
        <email>liupengyjy@chinamobile.com</email>
      </address>
    </author>
    <author initials="G." surname="Li" fullname="Guangpeng Li">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <city>Beijing</city>
          <country>China</country>
        </postal>
        <email>liguangpeng@huawei.com</email>
      </address>
    </author>
    <author initials="S." surname="Ren" fullname="Shoushou Ren">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <city>Beijing</city>
          <country>China</country>
        </postal>
        <email>renshoushou@huawei.com</email>
      </address>
    </author>

    <date year="2025" month="December" day="12"/>

    
    <workgroup>DETNET</workgroup>
    

    <abstract>


<?line 173?>

<t>This memo specifies a forwarding method for bounded latency and bounded jitter for Deterministic Networks and is a variant of the IEEE TSN Cyclic Queuing and Forwarding (CQF) method. Tagged CQF (TCQF) supports more than 2 cycles and indicates the cycle number via an existing or new packet header field called the tag to replace the cycle mapping in CQF which is based purely on synchronized reception clock.</t>

<t>This memo standardizes TCQF as a mechanism independent of the tagging method used. It also specifies tagging via the (1) the existing MPLS packet Traffic Class (TC) field for MPLS packets, (2)  the IP/IPv6 DSCP field for IP/IPv6 packets, and (3) a new TCQF Option header for IPv6 packets.</t>

<t>Target benefits of TCQF include low end-to-end jitter, ease of high-speed hardware implementation, optional ability to support large number of flow in large networks via DiffServ style aggregation by applying TCQF to
the DetNet aggregate instead of each DetNet flow individually, and support of wide-area DetNet
networks with arbitrary link latencies and latency variations as well as low accuracy clock synchronization.</t>



    </abstract>



  </front>

  <middle>


<?line 183?>

<section anchor="introduction"><name>Introduction</name>

<section anchor="terminology"><name>Terminology</name>

<dl>
  <dt>CQF</dt>
  <dd>
    <t>Cyclic Queuing and Forwarding.  A queuing mechanism defined by annex T of <xref target="IEEE802.1Q"/>.</t>
  </dd>
  <dt>DT</dt>
  <dd>
    <t>Dead Time. A term from CQF indicating the time during each cycle in which no frames can be sent because the the receiving node could not receive it into the desired cycle buffer.</t>
  </dd>
  <dt>TCQF</dt>
  <dd>
    <t>Tagged Cyclic Queuing and Forwarding. The mechanism specified in this memo.</t>
  </dd>
</dl>

</section>
</section>
<section anchor="overview-informative"><name>Overview (informative)</name>

<section anchor="cyclic-queuing-and-forwarding-cqf"><name>Cyclic Queuing and Forwarding (CQF)</name>

<t>Cyclic Queuing and Forwarding (CQF) is a bounded (guaranteed) per-hop
latency forwarding mechanism standardized for use in ethernet switched
networks by the IEEE TSN working group originally via <xref target="IEEE802.1Qch"/>
(802.1 Qch), which later became annex T of <xref target="IEEE802.1Q"/>.  See also <xref target="RFC9320"/>, Section 6.6.</t>

<t>CQF is not a separate forwarding mechanism, but it is simple a profile
of the IEEE Time Aware Shaper (TAS) standard, <xref target="IEEE802.1Qbv"/>, which introduce
Time-Gated Queues.</t>

<t>CQF uses a two-queue based forwarding mechanism on every switch along a
path between a sender and receiver. One queue is used to receive and
store frames destined toward a particular outgoing interface on the switch,
the other queue is used simultaneously to send frames to the same outgoing
interface. At every cycle time T_c interval these two queues are swapped, or
in terms of Time-Gated Queus, one is closed for sending, the other is opened
for sending. This operation is synchronized across all switches in the 
network by network wide synchronized clocks, so that all queues
open and close at the same time.</t>

<t>For a path of h hops, the end-to-end latency bound is between (h-1) * T_c + DT
and (h+1) * T_c. DT is the so-called dead time at the end of a cycle
during which no frames can be transmitted from the sending queue to ensure
that the last byte of the last frame will be received earlier than
the end of the same cycle on the receiving switch.</t>

<t>A core contributor to DT is the (physical) link between the sending
and receiving switch. DT needs to be larger than the latency of
this link, including physical propagation latency (speed of light), possible
error correction latencies, and interface serialization latency.</t>

<t>T_c needs to be choosen carefully: The larger it is, the higher the
bounded latency. The smaller it is, the fewer bytes (and hence frames)
will fit into a cycle.</t>

<t>To admit flows into a CQF network, the ingress switch uses per-flow
Time-Gated Queues. In the most simple case, such a gate is configured
to admit a maximum amount of bytes from the flow into every cycle. More
advanced admission control can be performed for bursty flows. For example
N bursty flows f_i = 0...(N-1) could share admitted bandwidth by each having their
burst admitted in different cycles c_i = c % N + c_i, where c is a continuous
increasing cycle number.</t>

</section>
<section anchor="highspeed"><name>Benefits of CQF with higher speed links</name>

<t>The typical CQF deployments in manufacturing networks with 1Gbps links
uses no less than hundreds of microseconds as a cycle interval.  In a
network with a small diameter, say less than 8 hops, it is sufficiently good to provide an
end-to-end latency bound in the order of several milliseconds.</t>

<t>With the increasing of link speed from 100Mbps to 1Gbps, 10Gbps, 100Gbps
or even higher in larger networks, either more bytes can be transmitted
within the same cycle interval or the smaller cycle interval is
required to transmit the same amount of bytes in a cycle as that in
low speed networks. Likewise, the serialization latency reduces with
higher speed links and DT reduces. This overall makes CQF for higher speed
networks more attractive than for lower speed networks.</t>

<t><xref target="Fig1"/> shows a simple calculation on the number of bytes that can
be transmitted in a cycle with different cycle intervals and link
speeds. A minimum of 1500 bytes is labeled with * as a baseline because
a typical maximum Ethernet frame is 1500 bytes and a selected cycle interval
should at least allow one such frame size to be transmitted unless
otherwise specified.</t>

<t>TBD: These numbers probbly need to be adjusted to reflect reducing DT based on
serialization latency.</t>

<figure title="Bytes transmitted within one cycle interval" anchor="Fig1"><artwork><![CDATA[
+----------+------------------------------------------------+
|          |           Bytes Transmitted in a Cycle         |
|Cycle Time+------------------------------------------------+
|          |             Link Speed                         |
|  (us)    |   100Mbps  |   1Gbps     |   10Gbps  | 100Gbps |
+----------+------------+-------------+-----------+---------+
|    1     |    12.5    |    125      |    1250   |   12500*|
+----------+------------+-------------+-----------+---------+
|   1.2    |     15     |    150      |    1500*  |   15000 |
+----------+------------+-------------+-----------+---------+
|    2     |     25     |    250      |    2500   |   25000 |
+----------+------------+-------------+-----------+---------+
|    4     |     50     |    500      |    5000   |   50000 |
+----------+------------+-------------+-----------+---------+
|    10    |    125     |   1250      |   12500   |  125000 |
+----------+------------+-------------+-----------+---------+
|    12    |    150     |   1500*     |   15000   |  150000 |
+----------+------------+-------------+-----------+---------+
|   120    |    1500*   |   15000     |   150000  | 1500000 |
+----------+------------+-------------+-----------+---------+
]]></artwork></figure>

<t>When the link speed is at 10Gbps, the cycle interval could be as
small as 1.2 us if a 1500 byte frame needs to be transmitted in one
cycle interval, and with 100Gbps links even 1 usec cycle time
allows for 8 frames of 1500 byte each.  These are not accurate calculations because there are
certainly other factors to determine the cycle interval.  However, it
shows that as the link speed increases, cycle interval can be greatly
reduced in practice while satisfying the minimum amount of data
transmitted in a single cycle.  The end-to-end latency bound when
applying CQF is determined by cycle interval and number of hops.
That is to say, CQFs with a smaller cycle interval have the potential
to meet more strict end-to-end latency requirements in higher link
speed networks or meet the same end-to-end latency requirement in
networks with much larger network diameter (number of hops).</t>

<t>Industry automation has some typical application period requirement,
e.g.  100 us to 2 ms for isochronous traffic, 500 us to 1 ms for
cyclic-synchronous and 2 to 20 ms for cyclic-asynchronous traffic.
The network cycle interval is usually a fraction of the application
period.  When the cycle interval is in the order of tens of
microseconds, CQF can be used to meet the most strict end-to-end
latency requirements.  For instance, if we assume the number of hops
is 24, when cycle interval is set to 10us, the end-to-end latency
bound can be around (24+1)*10 = 250 us which has the potential to
meet the latency bound requirement for isochronous traffic.</t>

<t>In summary a higher speed network makes the shorter cycle interval
feasible because sufficiently large traffic volume can be transmitted
within one cycle interval.  A shorter cycle interval further offers
shorter end-to-end latency and jitter bounds which provide CQF with
the potentials to meet more strict latency requirements in wider
deployments while preserving its simplicity of latency calculation
and provisioning.  Therefore there is a strong motivation to leverage
CQF and at the same time to make cycle interval as short as possible.</t>

</section>
<section anchor="cqfdt"><name>Challenges of CQF with higher latency links</name>

<t>Unlike the original targets for IEEE TSN work, DetNet not only targets
to support IETF forwarding planes (IP, MPLS,...), but also wide-area
networks with therefore longer physcial propagation latencies.</t>

<t>As shown in <xref target="Fig2"/> for fundamental (two buffer) CQF, the last byte
sent by node A in cycle (i-1) has to be ready for sending at node B
before the start of cycle i.  To realize it, DT or dead time is
imposed.  It is a time interval usually at the end of a cycle so that
a node should not send the scheduled CQF packets.</t>

<t>Dead time is at least the sum of the maximum propagation delay to the
next node, the maximum processing delay at the next node and the
maximum other time variations.  Therefore either the longer
propagation or longer processing delay makes dead time larger.
Packets from DetNet service is likely to be propagated over long
links in the wider area.  It takes around 5us per kilometer to
propagate, i.e. 0.5ms every hundred kilometers.  Hence the dead time
can be as large as milliseconds or tens of milliseconds in case of
hundred kilometers of longer links and larger processing delays.
That would make the dead time eat up most of the cycle interval when
cycle interval is short (e.g., at the same order or one order higher
of magnitude in time as dead time).  Then the useful time in a cycle
will be much reduced.  In some extreme cases, when the link is long
and the cycle interval is set to extremely short, the first packet
sent in a cycle by a node will not be possibly received in the same
cycle interval at the next node.  That makes the useful time in a
cycle reaches zero in two buffer CQF.  Then two buffer CQF will be no
longer suitable.</t>

<t>In result of these considerations, reasonable limits for the size
of TSN CQF networks are in the order of at most few Km per hop,
beyond which DT exceeds common cycle times and possible through
of CQF traffic is hence 0.</t>

<figure title="Fundamental Two Buffer CQF" anchor="Fig2"><artwork><![CDATA[
--------------------------------------------------------> Time

          |             |             |             |
Node A    |  cycle i-1  |   cycle i   |  cycle i+1  |
          |             |             |             |
Sending  ---------------+----------------------------------
          |+------+     |+------+     |+------+     |
          ||//////|     ||//////|     ||//////|     |
          |+------+     |+------+     |+------+     |
          |  buf_1      |  buf_2      |  buf_1      |
          |       |     |       |     |       |     |
          |       | DT  |       | DT  |       | DT  |
Node B    |       |<--->|       |<--->|       |<--->|
          |             |             |             |
Receiving--------------------------------------------------
          |     +------+|     +------+|     +------+|
          |     |//////||     |//////||     |//////||
          |     +------+|     +------+|     +------+|
          |       buf_1 |       buf_2 |       buf_1 |
          |             |             |             |
          |             |             |             |
Node B    |             |             |             |
          |             |             |             |
Sending  --------------------------------------------------
          |             |+------+     |+------+     |
          |             ||//////|     ||//////|     |
          |             |+------+     |+------+     |
          |             |  buf_1      |  buf_2

DT=Dead Time
]]></artwork></figure>

</section>
<section anchor="cqf-review"><name>Review of CQF benefits and challenges for DetNet</name>

<t>In review, CQF has a range of benefits for DetNet.</t>

<t><list style="numbers">
  <t>It provides bounded latency.</t>
  <t>It provided tightly bounded jitter.</t>
  <t>It has a very simple and easily standardized calculus for its bounded latency and jitter.</t>
  <t>It has very simple per-hop forwarding machinery (cyclic queues) easily supportable in high-speed network equipment.</t>
  <t>Like Diffserv forwarding, it does not use per-hop,per-flow state in the forwarding plane and therefore does not require per-hop,per-flow signaling with the DetNet controller-plane, allowing it to scale to large number of flows.</t>
  <t>The faster the links are, the lower the per-hop latency impact of the cyclic queuing mechanism.</t>
</list></t>

<t>The core limitation of CQF, which TCQF intends to solve, lies in its use of arrival time clock to determine the cycle into which the packet is to be placed, see <xref target="I-D.eckert-detnet-bounded-latency-problems"/> for more details.</t>

<t><list style="numbers">
  <t>Cycles times should be as short as feasible to support lower end to end latency (<xref target="highspeed"/>).</t>
  <t>When networks have longer links, or links with higher propagation jitter as in Metro and WAN, this increases the dead time, and hence reduces the possible utilization or need to increase cycle times.</t>
  <t>When shorter cycle times are feasible because of higher speed links, this would require an increase in clock-synchronization accuracy.</t>
</list></t>

</section>
<section anchor="tagged-cqf"><name>Tagged CQF</name>

<t>Tagging of CQF packets with cycle identifiers can be used to solve
the dilemma aforementioned with minor changes to the fundamental two buffer CQF.
This section introduces this mechanism with multipl buffers and
CQF cycle identification in the packet header. Note that we are also now
using the term packet (as used for IP, MPLS and other IETF forwarding planes) and
buffers for packets, as opposed to frames as used by IEEE.</t>

<section anchor="cqf-with-more-than-two-buffers"><name>CQF with more than two buffers</name>

<t>CQF can use more than two buffers to minimize the dead time and
increase the useful time in a cycle so as to support long link delay.
<xref target="Fig3"/> shows how a three buffer CQF works in a rotating manner in
general.  Node A sends packets in cycle (i-1).  The time interval
over which node B receives these packet spans two cycles, cycle (i-1)
and cycle i.  Hence a method is needed to make node B send them all
at once in cycle (i+1) in order to ensure packets in a single cycle
from the previous node always being sent out in one cycle at the
current node.</t>

<figure title="Three Buffer CQF" anchor="Fig3"><artwork><![CDATA[
--------------------------------------------------------> Time

          |             |             |             |
Node A    |  cycle i-1  |   cycle i   |  cycle i+1  |
          |             |             |             |
Sending  ---------------+----------------------------------
          |+----------+ |+----------+ |+----------+ |
          ||//////////| ||//////////| ||//////////| |
          |+----------+ |+----------+ |+----------+ |
          |  buf_1      |  buf_2         buf_3      |
          |           | |           | |           | |
          |         ->| |<-       ->| |<-       ->| |<-
          |            DT            DT            DT
          |
          -------------------------------------------------
Node B    |     +-----------+ +-----------+ +-----------+
          |     |///////////| |///////////| |///////////|
Receiving |     +-----------+ +-----------+ +-----------+
          |       buf_1 |       buf_2 |       buf_3 |
          |             |             |             |
          |             |             |             |
          |             |             |             |
          |             |             |             |
         ---------------|----------------------------------
Node B    |             |             |+----------+ |+----------+
          |             |             ||//////////| ||//////////|
Sending   |             |             |+----------+ |+----------+
          |             |                buf_1         buf_2

DT=Dead Time
]]></artwork></figure>

<t>More than three buffers will be required when the receiving interval
at node B for packets sent in a single cycle interval from node A
spans over more than two cycle interval boundaries.  This can happen
when the time variance (jitter) including propagation, processing, regulation,
clock synchronization variance (so called Maximum Time Interval Error - MTIE)
and other factors between two neighbouring DetNet nodes can become larger
than a single cycle tim.</t>

</section>
<section anchor="from-cqf-with-multiple-buffers-to-tcqf"><name>From CQF with multiple buffers to TCQF</name>

<t>Note that due to the variance in time, the receiving interval at the
downstream node can be much larger than one cycle interval in which
the upstream node transmits.  When time variance is large and cycle
interval and dead time are set small, the possible receiving time of
the last few packets from node A’s cycle (i-1) at node B can overlap
with the possible receiving time of the first few packets from node
A’s cycle i in different rounds of buffer rotations.  Hence, when the
buffer number is larger than two, if the receiving side still uses
the traditional CQF implicit time borderline to demarcate the
receiving packets from the consecutive cycles of the upstream node,
it may cause the ambiguity in identifying the right sending cycle at
the upstream node and further affect the correctness of the decision
of which output buffer to put the received packets at the current
node.</t>

<t><xref target="Fig4"/> shows such an ambiguity when time based cycle demarcation is
used.  The packet sent by node A in its cycle (i-1) can be received
at any time in the receiving interval indicated as “receiving window
for A’s buf_1” in Figure 4.  The receiving window refers to the time
interval between the earliest time that the first packet sent in a
given cycle from an upstream node is processed and enqueued in an
output buffer and the latest time that the last packet of the cycle
is processed and enqueued in an output buffer.  Network operators may
configure the size of the receiving window, taking the time variance
of their networks into account.  It can be seen that the spanning
time period of receiving window is longer than the cycle interval.
This is because there is a large time variance experienced between A
and B, e.g. varying processing time for different packets in
different cycles.  It does not mean the receiving interval for every
cycle always constantly span over such a large receiving window.  The
receiving window time interval indeed is determined by the worst case
time variance value and that should be used for regular time cycle
demarcation.</t>

<figure title="Three Buffer ambiguity" anchor="Fig4"><artwork><![CDATA[
--------------------------------------------------------> Time

           |        |        |        |        |
Node A     | cycle  | cycle  | cycle  | cycle  |
           |  i-1   |   i    |  i+1   |  i+2   |
Sending   ----------+--------+--------+--------+
           |+-----+ |+-----+ |+-----+ |+-----+ |
           ||/////| ||/////| ||/////| ||/////| |
           |+-----+ |+-----+ |+-----+ |+-----+ |
           | buf_1  | buf_2  | buf_3  | buf_4  |
           |      | |      | |      | |      | |
           |    ->| |<-  ->| |    ->| |    ->| |
           |      DT       DT       DT       DT
           |
          --------------------------------------
           |      +-----------+receiving window
Node B     |      |///////////|for A's buf_1
           |      +-----------+
Receiving  |    put to B's buf_1
           |
           |             ->|  |<- ambiguity window 1
           |
           |               +-----------+receiving window
           |               |///////////|for A's buf_2
           |        |      +-----------+
           |        |     put to B's buf_2
           |        |
           |        |             ->|  |<- ambiguity window 2
           |        |        |
           |        |        |      +-----------+receiving window
           |        |        |      |///////////|for A's buf_3
           |        |        |      +-----------+
           |        |        |     put to B's buf_3
           |        |        |
           |        |        |             ..........
           |        |        |
          -|--------|--------|--------|---------------
Node B     |        |        |        |        |        |
           |        |        | +-----+|+-----+ |+-----+ |+-----+
Sending    |        |        | |/////|||/////| ||/////| ||/////|
           |        |        | +-----+|+-----+ |+-----+ |+-----+
           |        |        |  buf_4 | buf_1  | buf_2  | buf_3

DT=Dead Time
]]></artwork></figure>

<t>When a packet is received in ambiguity window 1 in <xref target="Fig4"/>, node B
is not able to use the receiving time to determine which buffer is
the correct one to put the packet in because it cannot tell if the
packet is sent from cycle (i-1) or cycle i on node A.  If node B puts
the packet to the wrong output buffer, the packet may experience the
unexpected delay.  At the same time, the packet occupying the non-
designated buffer may break the contracts between the end hosts and
DetNet networks and then cause the unpredictable consequences.</t>

<t>It has been noted that the DT can be greatly increased to beat the
time variance in order to make the receiving windows do not overlap
so as to remove such ambiguity.  However, it is not always practical
and usually not desired because large DT will eat useful cycle time
and bring the low utilization issue as illustrated in <xref target="cqfdt"/>.
Therefore, it would be desired to keep DT as small as possible and at
the same time identify the cycle interval correctly.</t>

<t>With tagged CQF, the sending router A encodes the sending cycle identification in some
existing or new packet header field as specified later in this document.
This allows the receiving router B to determine the correct output port cycle buffer to
place the data packet into. Except for the need for the operator to
pre-configure this mapping on router B, based on the above described latency and jitter
of the link (and processing between the sending and receiving router,
tagging does not change the fundamental mechanism and benefits of CQF.
makes no change from the fundamental CQF.</t>

<t>Compared to CQF with multiple buffers, Tagged CQF allows to
operate with clock synchronization at significantly reduced accuracy
requirements than CQF. In CQF, the MTIE is an addend determing DT 
and should hence typically be less than 1% of the cycle time. In TCQF it
is an addent in the permitted receive window and can hence be for  example
as large as the cycle time, and such 100 times larger. A network using
TCQF with 100Gbps interfaces can hence can hence use the same or less
expensive clock synchronization setup than a CQF network with 1Gbps interfaces.
In addition, when conditions of the network connections change, the mappings
can dynamically changed from network operations.</t>

<t>CQF with multiple buffers but without tagging has been proposed to IEEE TSN
in <xref target="multipleCQF"/>, but has not been adopted. Instead of relying on a cycle
tag in a packet header, it still relies solely on the arrival time of packet,
and can hence not equally resolve arrival time ambiguities as TCQF can,
because it does not know the cycle from which the packet was sent.</t>

</section>
</section>
<section anchor="summary-of-tcqf-benefits-and-goals-for-detnet"><name>Summary of TCQF benefits and goals for DetNet</name>

<t>TCQF inherits the benefits of CQF for DetNet as outlined in <xref target="cqf-review"/>, and byusing a configurable number of three or more cycles, and signaling the cycle as part of a packet header, it resolves these problems as follows.</t>

<t><list style="numbers">
  <t>With three cycles, TCQF can support arbitrary latency links at arbitrary speeds without reduction of utilization because of longer links or higher link speeds (same cycle time, same clock accuracy, only change in lengths and speeds).</t>
  <t>With four or more cycles, TCQF can also eliminate Dead Time caused by variation of clock synchronization inaccuracies (MTIE) as well as jitter caused by link propagation and processing variation. The sum of cycles times needs to be larger than the total jitter to achieve this.</t>
</list></t>

<t>Prior documents describing the concept of TCQF (without using that name) include <xref target="I-D.qiang-detnet-large-scale-detnet"/> and <xref target="I-D.dang-queuing-with-multiple-cyclic-buffers"/>. TCQF does not depend on other elements of <xref target="RFC8655"/>, so it can also be used stand alone in otherwise non-deterministic IP/IPv6 or MPLS networks to achieve bounded latency and low jitter.</t>

<t>TCQF is likely especially beneficial when networks are architected to avoid per-hop, per-flow state even for traffic steering, which is the case for networks using SR-MPLS <xref target="RFC8402"/> for traffic steering of MPLS unicast traffic, SRv6 <xref target="RFC8986"/> for traffic steeering of IPv6 unicast traffic and/or BIER-TE <xref target="I-D.ietf-bier-te-arch"/> for tree engineering of MPLS multicast traffic by using the TC and/or DSCP header fields of BIER packets according to <xref target="RFC8296"/>.</t>

<t>In these networks, it is specifically undesirable to require per-flow signaling to non-edge forwarders (such as P-LSR in MPLS networks) solely for DetNet QoS because such per-flow state is unnecessary for traffic steering and would only be required for the bounded latency QoS mechanism and require likely even more complex hardware and manageability support than what was previously required for per-hop steering state (such as in RSVP-TE, <xref target="RFC4875"/>). Note that the DetNet architecture <xref target="RFC8655"/> does not include full support for this DiffServ model, which is why this memo describes how to use TCQF with the DetNet architecture per-hop, per-flow processing as well as without it.</t>

</section>
</section>
<section anchor="using-tcqf-in-the-detnet-architecture-and-mpls-forwarding-plane-informative"><name>Using TCQF in the DetNet Architecture and MPLS forwarding plane (informative)</name>

<t>This section gives an overview of how the operations of TCQF relates
to the DetNet architecture. We first revisit QoS with DetNet in the absence of TCQF
using an MPLS network as an example.</t>

<figure title="A DetNet MPLS Network" anchor="FIG-DetNet-MPLS"><artwork><![CDATA[
 DetNet MPLS       Relay       Transit         Relay       DetNet MPLS
 End System        Node         Node           Node        End System
    T-PE1          S-PE1        LSR-P          S-PE2       T-PE2
 +----------+                                             +----------+
 |   Appl.  |<------------ End-to-End Service ----------->|   Appl.  |
 +----------+   +---------+                 +---------+   +----------+
 | Service  |<--| Service |-- DetNet flow --| Service |-->| Service  |
 +----------+   +---------+  +----------+   +---------+   +----------+
 |Forwarding|   |Fwd| |Fwd|  |Forwarding|   |Fwd| |Fwd|   |Forwarding|
 +-------.--+   +-.-+ +-.-+  +----.---.-+   +-.-+ +-.-+   +---.------+
         :  Link  :    /  ,-----.  \   : Link :    /  ,-----.  \
         +........+    +-[ Sub-  ]-+   +......+    +-[ Sub-  ]-+
                         [Network]                   [Network]
                          `-----'                     `-----'
         |<- LSP -->| |<-------- LSP -----------| |<--- LSP -->|
  
         |<----------------- DetNet MPLS --------------------->|
]]></artwork></figure>

<t>The above <xref target="FIG-DetNet-MPLS"/>, is copied from <xref target="RFC8964"/>, Figure 2, 
and only enhanced by numbering the nodes to be able to better refer
to them in the following text.</t>

<t>Assume a DetNet flow is sent from T-PE1 to T-PE2 across S-PE1, LSR, S-PE2. 
In general, bounded latency QoS processing is then required on the
outgoing interface of T-PE1 towards S-PE1, and any further outgoing
interface along the path. When T-PE1 and S-PE2 know that their next-hop
is a service LSR, their DetNet flow label stack may simply have the
DetNet flows Service Label (S-Label) as its Top of Stack (ToS) LSE,
explicitly indicating one DetNet flow.</t>

<t>On S-PE1, the next-hop LSR is
not DetNet aware, which is why S-PE1 would need to send a label stack
where the S-Label is followed by a Forwarding Label (F-Label), and
LSR-P would need to perform bounded latency based QoS on that F-Label.</t>

<t>For bounded latency QoS mechanisms relying on per-flow regulator state (aka:
per-flow packet scheduling), such as in <xref target="TSN-ATS"/>, this requires the use of a
per-detnet flow F-Labels across the network from S-PE1 to S-PE2. These could
for for example be assigned/managed through RSVP-TE <xref target="RFC3209"/>
enhanced as necessary with QoS parameters matching the underlying bounded
latency mechanism (such as <xref target="TSN-ATS"/>).</t>

<t>With TCQF, a sequence of LSR and DetNet service node implements
TCQF with MPLS TC, ideally from T-PE1 (ingress) to T-PE2 (egress).  The ingress
node needs to perform per-DetNet-flow per-packet "shaping"/"regulating" to  assign
each packet of a flow to a particular TCQF cycle. This is specified in <xref target="ingress"/>.</t>

<t>All LSR/Service nodes after the ingress node only have to map a
received TCQF tagged DetNet packet to the configured cycle
on the output interface, not requiring any per-DetNet-flow QoS state.
These LSR/Service nodes do therefore also not require per-flow
interactions with the controller plane for the purpose of bounded latency.</t>

<t>Per-flow state therefore is only required on nodes that are 
DetNet service nodes, or when explicit, per-DetNet flow steering
state is desired, instead of ingress steering through e.g.: SR-MPLS.</t>

<t>Operating TCQF per-flow stateless across a service node, such as S-PE1, S-PE2
in the picture is only one option. It is of course equally feasible to
Have one TCQF domain from T-PE1 to S-PE2, start a new TCQF domain there,
running for example up to S-PE2 and start another one to T-PE2.</t>

<t>A service node must act as an egress/ingress edge of a TCQF domain if it needs
to perform operations that do change the timing of packets other than
the type of latency that can be considered in configuration of TCQF (see <xref target="calculation"></xref>).</t>

<t>For example, if T-PE1 is ingress for a TCQF domain, and T-PE2 is the egress,
S-PE1 could perform the DetNet Packet Replication Function (PRF)  without having to be a TQCF 
edge node as long as it does not introduce latencies not included in the TCQF
setup and the controller plane reserves resources for the multitude of flows
created by the replication taking the allocation of resources in the TCQF cycles into account.</t>

<t>Likewise, S-PE2 could perform the Packet Elimination Function without being
a TCQF edge node as this most likely does not introduce any non-TCQF acceptable
latency - and the controller plane accordingly reserves only for one flow
the resources on the S-PE2-&gt;T-PE2 leg.</t>

<t>If on the other hand, S-PE2 was to perform the Packet Reordering Function (PRF), this could
create large peaks of packets when out-of-order packets are released together.
A PRF would either have to take care of shaping out those bursts for the traffic
of a flow to again conform to the admitted CIR/PIR, or else the service node
would have to be a TCQF egress/ingress, performing that shaping itself as an
ingress function.</t>

</section>
<section anchor="forwarding"><name>TCQF per-flow stateless forwarding (normative)</name>

<section anchor="model"><name>Configuration Data model and tag processing for MPLS TC tags</name>

<t>The following data model summarizes the configuration parameters
as required for TCQF and discussed in further sections. 'tcqf' 
includes the parameters independent of the tagging on an interface.
'tcqf_*' describes the parameters for interfaces using MPLS TC and
IP DSCP tagging.</t>

<figure title="Encapsulation independent TCQF Configuration Data Model" anchor="FIG-Data-Model"><artwork><![CDATA[
# Encapsulation agnostic data
tcqf 
+-- uint16 cycles
+-- uint16 cycle_time
+-- uint32 cycle_clock_offset
+-- if_config[oif] # Outgoing InterFace
    +-- uint32 cycle_clock_offset
    +-- cycle_map[iif] # Incoming InterFace
        +--uint8 oif_cycle[iif_cycle]
]]></artwork></figure>

</section>
<section anchor="processing"><name>Packet processing</name>

<t>This section explains the TCQF packet processing and through
it, introduces the semantic of the objects in <xref target="FIG-Data-Model"/></t>

<t>tcqf contains the router wide configuration of TCQF parameters,
independent of the specific tagging mechanism on any interface. Any
interface can have a different tagging method. This document uses the term
router when it is irrelevant whether forwarding is for IP or MPLS packet,
and the term Label Switched Router (LSR) to indicate MPLS is used, or IP
router to indicate IP or IPv6 are used - independent of the specific encapsulation
used for IP or MPLS to carry the cycle identification.</t>

<t>The model represents a single TQCF domain, which is a set of
interfaces acting both as ingress (iif) and egress (oif)
interfaces, capable to forward TCQF packets amongst each other. A router
may have multiple TCQF domains each with a set of interfaces disjoint
from those of any other TCQF domain.</t>

<t>tcqf.cycles is the number of cycles used across all interfaces in the TCQF domain.
routers MUST support 3 and 4 cycles. The maximum number of supportable cycles
depends on the encapsulation. For example, to support interfaces with MPLS TC tagging,
7 or fewer cycles MUST be used across all interfaces in the CQF domain. See <xref target="mpls"/>.</t>

<t>The unit of tcqf.cycle_time is micro-seconds.
routers MUST support configuration of cycle-times of 20,50,100,200,500,1000,2000 usec.</t>

<t>Cycles start at an offset of tcqf.cycle_clock_offset in units of nsec as follows. 
Let clock1 be a timestamp of the local reference clock for TCQF, at which
cycle 1 starts, then:</t>

<t>tcqf.cycle_clock_offset = (clock1 mod (tcqf.cycle_time * tcqf.cycles) )</t>

<t>The local reference clock of the router is expected to be synchronized with
the neighboring LSR/router in TCQF domain.  tcqf.cycle_clock_offset can be configurable
by the operator, or it can be read-only. In either case will the operator be
able to configure working TCQF forwarding through appropriately calculated
cycle mapping.</t>

<t>tcqf.if_config[oif] is optional per-interface configuration of TCQF parameters.
tcqf.if_config[oif].cycle_clock_offset may be different from tcqf.cycle_clock_offset,
for example, when interfaces are on line cards with independently synchronized clocks,
or when non-uniform ingress-to-egress propagation latency over a complex router/LSR
fabric makes it beneficial to allow per-egress interface or line card configuration
of cycle_clock_offset. It may be configurable or read-only.</t>

<t>The value of -1 for tcqf.if_config[oif].cycle_clock_offset is used to indicate
that the domain wide tcqf.cycle_clock_offset is to be used for oif.
This is the only permitted negative number for this parameter.</t>

<t>When a packet is received from iif with a cycle value of iif_cycle and the
packet is routed towards oif, then the cycle value (and buffer) to use on
oif is tcqf.if_config[oif].cycle_map[iif].oif_cycle[iif_cycle]. This is
called the cycle mapping and is must be configurable. This cycle mapping
always happens when the packet is received with a cycle tag on an interface
in a TCQF domain and forwarded to another interface in the same TCQF domain.</t>

<t>This encapsulation independent data model only defines how to map from
a received packets cycle to a sending interface cycle buffer and hence sent
packet cycle. It does not specify how the cycle identifier is encoded in
the received or sent packet. This is amended by the specification in the following
sections.</t>

<t>This data model does therefore also not determine whether interfaces use IP/IPv6, MPLS
or any other encapsulation. This is determined by the configuration of the DetNet domain. A mixed
use of MPLS and IP/IPv6 interfaces is possible with this data model, but
at the time of writing this document not supported by DetNet.</t>

</section>
<section anchor="mpls"><name>TCQF for MPLS with TC tagging</name>

<t>This section describes operation of TCQF for MPLS packets using the
Traffic Class (TC) field of MPLS label to carry the cycle-id. To support
this encapsulation, the TCQF Data Model as defined in <xref target="FIG-Data-Model"/>
is expanded as follows.</t>

<figure title="TCQF Configuration Data for MPLS TC" anchor="FIG-Data-Model-TC"><artwork><![CDATA[
# MPLS TC tagging specific data
tcqf_tc[oif]
+--uint8 tc[oif_cycle]
]]></artwork></figure>

<t>tcqf_tc[oif].tc[oif_cycle] defines how to map from the internal cycle number
oif_cycle to an MPLS TC value on interface oif. tcqf_tc[oif] MUST be
configured, when oif uses MPLS. This oif_cycle &lt;=&gt; tc mapping is not only
 used to map from internal cycle number to MPLS TC tag when sending
packets, but also to map from MPLS TC tag to the internal cycle number when
receiving packets.</t>

<t>In the terminology of <xref target="RFC3270"/>, TCQF QoS as defined here, is 
TC-Inferred-PSC LSP (E-LSP) behavior: Packets are determined to
belong to the TCQF PSC solely based on the TC of the received
packet.</t>

<t>The internal cycle number SHOULD be assigned from the Top of Stack (ToS)
MPLS label TC bits before any other label stack operations
happens. On the egress side, the TC value of the ToS MPLS label
SHOULD be assigned from the internal cycle number after any label
stack processing.</t>

<t>With this order of processing, TCQF can support forwarding of
packets with any label stack operations such as label swap in the
case of LDP or RSVP-TE created LSP, Penultimate Hop Popping (PHP),
or no label changes from SID hop-by-hop forwarding and/or SID/label
pop as in the case of SR-MPLS traffic steering.</t>

</section>
<section anchor="dscp"><name>TCQF for IP/IPv6 with DSCP tagging</name>

<t>This section describes operation of TCQF for IP/IPv6 packets using the
Differentiated Services Code Point (DSCP) field of IP/IPv6 packets to carry the cycle-id.
To support this encapsulation, the TCQF Data Model as defined in <xref target="FIG-Data-Model"/>
is expanded as follows.</t>

<figure title="TCQF Configuration Data for IP/IPv6 DSCP" anchor="FIG-Data-Model-DSCP"><artwork><![CDATA[
# IP/IPv6 DSCP tagging specific data
tcqf_dscp[oif]
+--uint8 dscp[oif_cycle]
]]></artwork></figure>

<t>tcqf_dscp[oif].dscp[oif_cycle] defines how to map from the internal cycle number
oif_cycle to an IP/IPv6 DSCP value on interface oif. tcqf_dscp[oif] MUST be
configured, when oif uses DSCP tagging of IP/IPv6 packets for TCQF. This
oif_cycle &lt;=&gt; idscp mapping is not only used to map from internal cycle number to the
DSCP tag when sending packets, but also to map from IP/IPv6 DSCP to the internal cycle number when
receiving packets.</t>

<t>As how DetNet domains are currently assumed to be single administrative network
operator domains, this document does not ask for standardization
of the DSCP to use with TCQF. Instead, deployments wanting to use TCQF with
IP/IPv6 encapsulation and DSCP tagging need to assign within their domain DSCP from the
xxxx11 "EXP/LU" Codepoint space according to <xref target="RFC2474"/>, Section 6. This
allows up to 16 DSCP for intradomain use and hence up to 16 cycle identifiers.</t>

</section>
<section anchor="option"><name>TCQF for IPv6 with IPv6 Option tagging</name>

<t>This section describes operation of TCQF for IPv6 packets without having
to rely on DSCP by defining a new IPv6 option for DetNet.  This option is to be placed in the
IPv6 HbH (Hop-by-Hop) Options or DOH (Destination Option Header) header.
To support this encapsulation, the TCQF Data Model as defined in <xref target="FIG-Data-Model"/>
is expanded as follows.</t>

<figure title="TCQF Configuration Data for IPv6 TCQF Option Header" anchor="FIG-Data-Model-IPV6OH"><artwork><![CDATA[
# IPv6 TCQF Option tagging specific data
tcqf_ipv6oh[oif]
+--uint8 ipv6oh[oif_cycle]
]]></artwork></figure>

<section anchor="tcqf-option-format"><name>TCQF Option Format</name>

<t>The TCQF Option helps the receiving port to identify in which
time cycle interval the packet is sent from the upstream router.  It
can be used to determine the output port cycle buffer to enqueue the
packet.</t>

<figure title="TCQF Option Format" anchor="Fig5"><artwork><![CDATA[
 0                   1                   2                   3
 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|  Option Type  |  Opt Data Len |E|    Flags    |   Cycle Id    |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
.                                                               .
~         (64-bit extension if flag E-bit is 1)                 ~
.                                                               .
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
]]></artwork></figure>

<t>TCQF-Option fields:</t>

<t><list style="symbols">
  <t>Option Type: 8-bit identifier of the type of option.  Value TBD by
IANA.  If the processing IPv6 node does not recognize the Option
Type it must discard the packet and return an ICMPv6 message (the
highest-order 2 bits = 10).  The Option Data of this option may
change en route to the packet's final destination (the third-
highest-order bit=1).</t>
  <t>Opt Data Len: 8-bit length of the option data.</t>
  <t>Flags: 8-bit field to indicate what TCQF Option information
follows.  The leftmost bit is called E-bit.  When E-bit set to 1,
there is a 64-bit extension in length after Cycle Id.</t>
  <t>Cycle Id: 8-bit field to indicate the time cycle ID at output port
of the upstream node when the packet is sent out. This is the
packet header field name for the data model ipv6oh[oif_cycle]
element.</t>
  <t>64-bit extension: This field contains values required for a
possible additional options, such as timestamp.  This field exists only
when E-bit in Flags field is set to one.  [Editor's Note: Text
will be modified or added as specific uses for this field are
identified]</t>
</list></t>

</section>
<section anchor="tcqf-option-processing"><name>TCQF Option Processing</name>

<t>A packet carrying the TCQF Option with Cycle Id does not change
the fundamental cyclic queuing and forwarding behaviors of TCQF over
the encapsulation independent forwarding behavior described above (<xref target="processing"/>).</t>

<t>Compared to DSCP it does not introduce a limited number of cycle-ids, and
eliminates the possible operation consideration to use multiple DSCP for
effectively a single per-hop forwarding behavior, which otherwise would
be a novel aspect that could cause issues for example with diagnostics or
other operational standards. It also allows easier extensions with other
potentially beneficial DetNet features in the same Option header.</t>

<t>As part of the packet processing of <xref target="processing"/>, the Cycle ID field
of the option heade is rewritting from tcqf.ipv6oh[oif_cycle], in the
same way as DSCP wold be rewritten from tcqf.dscp[oif_cycle].</t>

</section>
<section anchor="encapsulation-of-tcqf-option-for-deterministic-ip-dip-data-plane"><name>Encapsulation of TCQF Option for Deterministic IP (DIP) data plane</name>

<t>When used in IPv6 (<xref target="RFC8200"/>) networks, the TCQF Option can be placed in
an HbH extension header or Destination Option Header (DOH).</t>

<figure title="TCQF Option Encapsulated in HbH for Deterministic IP data plane" anchor="Fig6"><artwork><![CDATA[
+-----------------------------------+
|         DetNet IP Packet          |
+-----------------------------------+
|            other EHs              |
+-----------------------------------+
|        IPv6 Hop-by-Hop Ex Hdr     |
|         (DIP-TCQF Option)         |
+-----------------------------------+
|            IPv6 Header            |
+-----------------------------------+
|             Data-Link             |
+-----------------------------------+
|             Physical              |
+-----------------------------------+
]]></artwork></figure>

<t><xref target="Fig6"/> shows the encapsulation of TCQF option in HbH
extension header for deterministic IP (DIP）data plane.  When every DetNet forwarding node along the path
is provisioned to use TCQF as the queuing mechanism, this
option should be placed here.  If a router does not support this
option, it discards the packet and returns an ICMP message.</t>

<t>In some deployments the path selection is indicated using IPv6
routing header (RH) by specifying a set of nodes that must be
traversed by the packet along its path to the destination.  When such
a source routing mechanism is used, TCQF Option is placed in
DOH (Destination Option Header) as shown in <xref target="Fig7"/> for Deterministic IP data plane. Then the TCQF
Option will be processed by the specified in-path routers.</t>

<figure title="TCQF Option Encapsulated in DOH for Deterministic IP data plane" anchor="Fig7"><artwork><![CDATA[
+-----------------------------------+
|         DetNet IP Packet          |
+-----------------------------------+
|         other EHs including RH    |
+-----------------------------------+
|       IPv6 Destination Ex Hdr     |
|         (DIP-TCQF Option)         |
+-----------------------------------+
|            IPv6 Header            |
+-----------------------------------+
|             Data-Link             |
+-----------------------------------+
|             Physical              |
+-----------------------------------+
]]></artwork></figure>

<t>(TBD: Should and how TCQF Option be used in SRv6 ?)</t>

</section>
</section>
<section anchor="tcqf-pseudocode-normative"><name>TCQF Pseudocode (normative)</name>

<t>The following pseudocode restates the forwarding behavior of <xref target="forwarding"/>
in an algorithmic fashion as pseudocode. It uses the objects of the TCQF configuration
data model defined in <xref target="model"></xref>.</t>

<figure title="TCQF Pseudocode" anchor="FIG-Pseudocode"><artwork><![CDATA[
void receive(pak) {
  // Receive side TCQF - retrieve cycle of received packet
  // from packet internal header
  iif = pak.context.iif
  if (tcqf.if_config[iif]) { // TCQF enabled on iif
    if (tcqf_tc[iif]) {      // MPLS TCQF enabled on iif
      tc = pak.mpls_header.lse[tos].tc
      pak.context.tcqf_cycle = map_tc2cycle( tc, tcqf_tc[iif])
    } else
    if (tcqf_ipv6oh[iif]) {    // IPv6 Option Header used on iif
      cycle_id = pak.ipv6_header.tcqf_oh[cycle_id]
      pak.context.tcqf_cycle = 
        map_ipv6oh2cycle( cycle_id, tcqf_ipv6oh[iif])
    } else
    if (tcqf_dscp[iif]) {      // IP DSCP TCQF used on iif
      dscp = pak.ip_header.dscp
      pak.context.tcqf_cycle = map_dscp2cycle( dscp, tcqf_dscp[iif])
    } else // ... other encaps
  }
  forward(pak);
}

// ... Forwarding including any label stack operations

void forward(pak) {
  oif = pak.context.oif = forward_process(pak)

  if(ingres_flow_enqueue(pak))
    return // ingress packets are only enqueued here.

  if(pak.context.tcqf_cycle) // non TCQF packets cycle is 0
    if(tcqf.if_config[oif]) {    // TCQF enabled on OIF
      // Map tcqf_cycle iif to oif - encap agnostic
      cycle = pak.context.tcqf_cycle
            = map_cycle(cycle,
              tcqf.if_config[oif].cycle_map[[iif])
  
      // MPLS TC-TCQF
      if(tcqf.tc[oif]) {
        pak.mpls_header.lse[tos].tc = map_cycle2tc(cycle, tcqf_tc[oif])
      } else
      if (tcqf_ipv6oh[oif]) { // IPv6 Option Header used on iif
        pak.ipv6_header.tcqf_oh[cycle_id] =
          map_cycle2ipv6oh(cycle, tcqf_ipv6oh[oif])
      } else
      // IP DSCP TCQF enabled on iif
      if (tcqf_dscp[oif]) {
        pak.ip_header.dscp = map_cycle2dscp(cycle, tcqf_dscp[oif])
      } // else...  other future encap/tagging options for TCQF
  
      tcqf_enqueue(pak, oif.cycleq[cycle,iif])  // [3]
      return
    } else {
      // Forwarding of egress TCQF packets [1]
    }
  }
  // ... non TCQF OIF forwarding [2]
}

// Started when TCQF is enabled on an interface
// dequeues packets from oif.cycleq
// independent of encapsulation
void send_tcqf(oif) {
  cycle = 1
  cc =  tcqf.cycle_time *
        tcqf.cycle_time
  o =   tcqf.cycle_clock_offset
  nextcyclestart = floor(tnow / cc) * cc + cc + o

  while(1) {
    ingress_flow_2_tcqf(oif,cycle) // [5]
    wait_until(tnow >= nextcyclestart); // wait until next cycle
    nextcyclestart += tcqf.cycle_time
    forall(iif) {
      forall(pak = tcqf_dequeue(oif.cycleq[cycle,iif]) {
        schedule to send pak on oif before nextcyclestart; // [4]
      }
    }
    cycle = (cycle + 1) mod tcqf.cycles + 1
  }
}
]]></artwork></figure>

<t>Processing of ingress TCQF packets is performed
via ingres_flow_enqueue(pak) and
ingress_flow_2_tcqf(oif,cycle) as explained in <xref target="ingres_pseudocode"/>.</t>

<t>Packets in a cycle buffer can be sent almost arbitrarily within the time
period of the cycle. They also do not need to be sent as soon as possible,
as long as all will be sent within that period. There is no need to send them
in the order of their arrival except that packets from the same ingres
flow that end up in the same cycle must not be reordered across any number of
tcqf hops. The pseudocode describes this by using a queue oif.cycleq[cycle,iif] ([3]) for
all packets from the same iif. The pseudocode describes the oterwise
arbitrary scheduling of all packets within the cycle time via the
statement shown in [4].</t>

<t>Ingress packets are passed from their ingress queues to the next cycle queue via [5].</t>

<t>Processing of egres TCQF packets is out-of-scope. 
It can performed by any non-TCQF packet forwarding mechanism such as
some strict priority queuing in step [2], and packets could accordingly be
marked with an according packet header traffic class indicator for
such a traffic class in step [1].</t>

</section>
</section>
<section anchor="ingress"><name>TCQF Per-flow Ingress forwarding (normative)</name>

<t>Ingress flows in the context of this text
are packets of flows that enter the router from a non-TCQF interface
and need to be forwarded to an interface with TCQF.</t>

<t>In the most simple case, these packets are sent by the
source and the router is the first-hop router.
In another case, the routers ingress interface
connects to a hop where the previous router(s) did
perform a different bounded latency forwarding mechanism
than TCQF.</t>

<section anchor="ingress-flows-configuration-data-model"><name>Ingress Flows Configuration Data Model</name>

<figure title="TCQF Ingress Configuration Data Model" anchor="FIG-IData-Model"><artwork><![CDATA[
# Extends above defined tcqf
tcqf
...
| Ingress Flows, see below (TBD:
+-- iflow[flowid]
    +-- uint32 csize # in bits
]]></artwork></figure>

<t>The data model shown in <xref target="FIG-IData-Model"/> expands the tcqf data
model  from <xref target="FIG-Data-Model"/>. For every DetNet flow for which
this router is the TCQF ingress, the controller plane has to specify a maximum 
number of bits called csize (cycle size) that are permitted to 
go into each individual cycle.</t>

<t>Note, that iflow[flowid].csize is not specific to the sending
interface because it is a property of the DetNet flow.</t>

</section>
<section anchor="ingres_pseudocode"><name>Ingress Flows Pseudocode</name>

<t>When a TCQF ingress is received, it first has to be enqueued into a
per-flow queue. This is necessary because the permitted
burst size for the flow may be larger than what can fit
into a single cycle, or even into the number of cycles
used in the network.</t>

<figure title="TCQF Ingress Enqueue Pseudocode" anchor="FIG-Ingress-enqueue"><artwork><![CDATA[
bool ingres_flow_enqueue(pak) {
  if(!pak.context.tcqf_cycle &&
      flowid = match_detnetflow(pak)) {
    police(pak) // according to RFC9016 5.5
    enqueue(pak, flowq[oif][flowid])
    return true
  }
  return false
}
]]></artwork></figure>

<t>ingres_flow_enqueue(pak) as shown in <xref target="FIG-Ingress-enqueue"/>
performs this enqueuing of the packet. Its position
in the DetNet/TCQF forwarding code is shown in 
<xref target="FIG-Pseudocode"/>.</t>

<t>police(pak): If the router is not only the TCQF ingress router, but also
the first-hop router from the source, ingres_flow_enqueue(pak)
will also be the place where policing of the flows packet
according to the Traffic Specification of the flow would happen -
to ensure that packets violating the Traffic Specification
will not be forwarded, or be forwarded with lower priority
(e.g.: as best effort). This policing and resulting forwarding
action is not specific to TCQF and therefore out of scope for
this text. See <xref target="RFC9016"/>, section 5.5.</t>

<figure title="TCQF Ingress Pseudocode" anchor="FIG-Ingress-2-TCQF"><artwork><![CDATA[
void ingress_flow_2_tcqf(oif, cycle) {
  foreach flowid in flowq[oif][*] {
    free = tcqf.iflow[flowid].csize
    q = flowq[oif][flowid]
    while(notempty(q) &&
          (l = head(q).size) <= free) {
      pak = dequeue(q)
      free -= l
      tcqf_enqueue(pak, oif.cycleq[cycle,internal])
    }
  }
}
]]></artwork></figure>

<t>ingress_flow_2_tcqf(oif, cycle) as shown in
<xref target="FIG-Ingress-2-TCQF"/> transfers ingress DetNet flow
packets from their per-flow queue into the queue of the cycle
that will be sent next. The position of ingress_flow_2_tcqf() 
in the DetNet/TCQF forwarding code is shown in <xref target="FIG-Pseudocode"/>.</t>

</section>
</section>
<section anchor="implementation-deployment-operations-and-validation-considerations-informative"><name>Implementation, Deployment, Operations and Validation considerations (informative)</name>

<section anchor="solution-scope-taxonomy-and-status-for-detnet-adoption-considerations"><name>Solution Scope, Taxonomy and Status for DetNet adoption considerations</name>

<section anchor="solution-scope"><name>Solution scope</name>

<t>TCQF is proposed as a solution not standalone, but in conjunction with <xref target="I-D.eckert-detnet-flow-interleaving"/>
as a per-flow mechanism to be used on the ingress TCQF router to allow more flexible per-flow management
of admission of flow bursts into cycles than presented in this document. The reason for splitting up
the proposal into two documents is because <xref target="I-D.eckert-detnet-flow-interleaving"/> can be combined
with all "mostly-synchronous" per-hop mechanisms, for example beyong TCQF also (of course) CQF and
GLBF (<xref target="I-D.eckert-detnet-glbf"/>.</t>

</section>
<section anchor="taxonomy"><name>Taxonomy</name>

<t>Using the section number/titles of the taxonomy document
<xref target="I-D.ietf-detnet-dataplane-taxonomy"/> the TCQF technology
can be classified as follows.</t>

<t><list style="symbols">
  <t>4.1 Per Hop Dominant Factor for Latency Bound  <vspace blankLines='1'/>
The per-hop dominan latency bound is Category 3. The per-hop latency for each
class is determined by the cycle size, which has to be determined by the
sum of burst sizes required by the flows. This burst can be split up across
multiple cycles by the mechanisms described in <xref target="I-D.eckert-detnet-flow-interleaving"/>
for flows whose rate is low enough that they do not need resources in every cycle.</t>
  <t>5.1 Periodicity  <vspace blankLines='1'/>
TCQF is Periodic, however, by using tagging it reduces the required synchronization
across the network (using CQF as a reference) by potentially a factor of 100 or
more, allowing to use the same or even less stringent clock synchronization at 100 times
or more speedup versus current CQF networks.</t>
  <t>5.2.  Traffic Granularity  <vspace blankLines='1'/>
TCQF has Class level granularity. In its current form, this draft only describes operation
for a single cycle class, but it can easily be extended to use multiple classes. In addition,
additional differentiation into more classes can happen at the ingress edge through
<xref target="I-D.eckert-detnet-flow-interleaving"/>. However, those additional options do not increase
the amount of per-hop state in the TCQF network, that will stay limited to the cycle states
required for the per-hop classes (e.g.: just one class now). Hence TCQF maintains minimal
state per-hop.</t>
  <t>5.3.  Time Bounds  <vspace blankLines='1'/>
TCQF is Bounded (Left and Right bounded) as determind by the time in which the cycle the packet is
in is sent. In result, The total end-to-end jitter of a packet is limited to the 
cycle time deployed, as is the per-hop jitter.</t>
  <t>5.4 Service Order  <vspace blankLines='1'/>
TCQF service order is solely arrival based.</t>
  <t><list style="numbers">
      <t>Suitable Categories for DetNet</t>
    </list>
TCQF is "6.3.  Class level periodic bounded category" according to the categorization.</t>
</list></t>

</section>
<section anchor="status"><name>Status</name>

<t>TCQF has a high-speed (100Gbps interface) ASIC/FPGA implementation which was deployed and
tested by an academic network test organization, a test report is in <xref target="CENI"/>. There is
also a large-scale simulation of the algorithm/mechanisms and results presented at a
peer reviewed academic conference, see <xref target="LDN"/>.</t>

</section>
</section>
<section anchor="high-speed-implementation"><name>High-Speed Implementation</name>

<t>High-speed implementations with programmable forwarding planes of TCQF
packet forwarding require Time-Gated Queues for the cycle queues,
such as introduced by <xref target="IEEE802.1Qbv"/> and also employed in CQF <xref target="IEEE802.1Qch"/>.</t>

<t>Compared to CQF, the accuracy of clock synchronization across the nodes
is reduced as explained in <xref target="calculation"/> below.</t>

<t>High-speed forwarding for ingress packets as specified in <xref target="ingress"/>
above would require to pass packets first into a per-flow queue and
then re-queue them into a cycle queue. This is not ideal for
high speed implementations.  The pseudocode for ingres_flow_enqueue()
and ingress_flow_2_tcqf(), like the rest of the pseudocode in this
document is only meant to serve as the most compact and hopefully
most easy to read specification of the desired externally observable
behavior of TCQF - but not as a guidance for implementation, especially not
for high-speed forwarding planes.</t>

<t>High-speed forward could be implemented with single-enqueueing into
cycle queues as follows:</t>

<t>Let B[f] be the maximum amount of data that the router would need to
buffer for ingress flow f at any point in time. This can be calculated
from the flows Traffic Specification. For example, when using the
parameters of <xref target="RFC9016"/>, section 5.5.</t>

<figure><artwork><![CDATA[
B[f] <= MaxPacketsPerInterval*MaxPayloadSize*8

maxcycles = max( ceil( B[f] / tcqf.iflow[f].csize) | f)
]]></artwork></figure>

<t>Maxcycles is the maximum number of cycles required so that packets
from all ingress flows can be directly enqueued into maxcycles queues.
The router would then not cycle across tcqf.cycles number of queues,
but across maxcycles number of queues, but still cycling across tcqf.cycles
number of cycle tags.</t>

<t>Calculation of B[f] and in result maxcycles may further be refined (lowered)
by additionally known constraints such as the bitrates of the ingress interface(s)
and TCQF output interface(s).</t>

</section>
<section anchor="calculation"><name>Controller plane computation of cycle mappings</name>

<t>The cycle mapping is computed by the controller plane by taking at minimum
the link, interface serialization and node internal forwarding latencies as well
as the cycle_clock_offsets into account.</t>

<figure title="Calculation reference" anchor="Calc1"><artwork><![CDATA[
Router  . O1
 R1     . | cycle 1 | cycle 2 | cycle 3 | cycle 1 |
        .    .
        .     ............... Delay D
        .                    .
        .                    O1'
        .                     | cycle 1 |
Router  .   | cycle 1 | cycle 2 | cycle 3 | cycle 1 |
  R2    .   O2

CT  = cycle_time
C   = cycles
CC  = CT * C
O1  = cycle_clock_offset router R1, interface towards R2
O2  = cycle_clock_offset router R2, output interface of interest
O1' = O1 + D
]]></artwork></figure>

<t>Consider in <xref target="Calc1"/> that Router R1 sends packets via C = 3 cycles with a
cycle_clock offset of O1 towards Router R2. These packets arrive
at R2 with a cycle_clock offset of O1' which includes through D all latencies
incurred between releasing a packet on R1 from the cycle buffer until
it can be put into a cycle buffer on R2: serialization delay on R1,
link delay, non_CQF delays in R1 and R2, especially forwarding in
R2, potentially across an internal fabric to the output interface
with the sending cycle buffers.</t>

<figure title="Calculating cycle mapping" anchor="Calc2"><artwork><![CDATA[
A = ( ceil( ( O1' - O2 ) / CT) + C + 1) mod CC
map(i) = (i - 1 + A) mod C + 1
]]></artwork></figure>

<t><xref target="Calc2"/> shows a formula to calculate the cycle mapping between
R1 and R2, using the first available cycle on R2. In the example
of <xref target="Calc1"/> with CT = 1, (O1' - O2) =~ 1.8, A will be 0, resulting
in map(1) to be 1, map(2) to be 2 and map(3) to be 3.</t>

<t>The offset "C" for the calculation of A is included so that
a negative (O1 - O2) will still lead to a positive A.</t>

<t>In general, D will be variable [Dmin...Dmax], for example because
of differences in serialization latency between min and max size
packets, variable link latency because of temperature based length
variations, link-layer variability (radio links) or in-router
processing variability. In addition, D also needs to account for the
drift between the synchronized clocks for R1 and R2. This
is called the Maximum Time Interval Error (MTIE).</t>

<t>Let A(d) be A where O1' is calculated with D = d. To account for
the variability of latency and clock synchronization, map(i) has to
be calculated with A(Dmax), and the controller plane needs to
ensure that that A(Dmin)...A(Dmax) does cover at most (C - 1) cycles.</t>

<t>If it does cover C cycles, then C and/or CT are chosen too small,
and the controller plane needs to use larger numbers for either.</t>

<t>This (C - 1) limitation is based on the understanding that there is only
one buffer for each cycle, so a cycle cannot receive packets
when it is sending packets. While this could be changed by
using double buffers, this would create additional implementation
complexity and not solve the limitation for all cases, because
the number of cycles to cover [Dmin...Dmax] could also be (C + 1)
or larger, in which case a tag of 1...C would not suffice.</t>

</section>
<section anchor="link-speed-and-bandwidth-sharing"><name>Link speed and bandwidth sharing</name>

<t>TCQF hops along a path do not need to have the same bitrate, they
just need to use the same cycle time. The controller plane has to then
be able to take the TCQF capacity of each hop into account when
admitting flows based on their Traffic Specification and TCQF csize.</t>

<t>TCQF does not require to be allocated 100% of the
link bitrate. When TCQF has to share a link with other traffic
classes, queuing just has to be set up to ensure that all
data of a TCQF cycle buffer can be sent within the TCQF
cycle time. For example by making the TCQF cycle queues the
highest priority queues and then limiting their capacity through
admission control to leave time for other queues to be served
as well.</t>

</section>
<section anchor="controller-plane-considerations"><name>Controller-plane considerations</name>

<t>TCQF is applicable to both centralized as well as decentralized/distributed
controller-plane models. From the perspective of the controller plane. If
the controller-plane is centralized, then it is logically very simple to
perform admission control for any additional flow by checking that there
is sufficient bandwidth for the amount of bits required for the flow on
every cycle along the intended path. Likewise, path computation can be
done to determine on which non-shortest path those resources are available.</t>

<t>More efficient use of resources can be achieved by considering that flows
with low bit rates would not need bits reserved in every cycle, but only in
every N'th cyce. This requires different gates on ingres to admit packets
from such flows than shown in this document and more complex admission control
that attempts for example to interleave multiple flows across different
set of cycles to as best as possible utilize all cycles. This is the same
complexity as possible in TSN technologies. Beside the admission control
and different ingres policing, such enhancements have no impact on the
per-hop TCQF forwarding and can thus potentially be added incrementally.</t>

<t>Decentralized or distributed controller planes including on-path, per-flow
signaling, such as one using the mechanisms of RSVP-TE, <xref target="RFC3209"/> is
equally feasible with TCQF. In this case one of the potential benefits of TCQ is not
leveraged, which is the complete removal of per-hop,per-flow awarenes on
each router. Nevertheless, the controller-plane only introduces the need
for this state maintenance into the control-plane of each router, but
does not change the TCQF forwarding plane, but maintains its per-hop, per-flow
non-stateful nature and resulting performance/cost benefits.</t>

</section>
<section anchor="validation"><name>Validation</name>

<t><xref target="LDN"/> describes an accurate simualtion based validation of TCQF 
and provides further details on the mathematical models.</t>

<t><xref target="CENI"/> is a report summary of a
100Gbps link speed commercial router validation implementation of TCQF deployed and measured in a research
testbed with a range of up to 2000km across China, operated by the China Environment for Network Innovations (CENI).
The report also provides a reference to a more detailled version of the report. Note that both reports are in chinese. 
TCQF is called DIP in these reports.</t>

</section>
</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>TBD.</t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<t>This document defines a new TCQF-Variant Option for the “Destination
Options and Hop-by-Hop Options” under the “Internet Protocol Version
6 (IPv6) Parameters” registry <xref target="IPV6-PARMS"/> with the suggested values
in <xref target="Fig9"/>.</t>

<figure title="TCQF Option Code in Destination Options and Hop-by-Hop Options" anchor="Fig9"><artwork><![CDATA[
+------+-----+-----+-------+--------------------+-------------+
| Hexa | act | chg | rest  | Description        | Reference   |
+------+-----+-----+-------+--------------------+-------------+
| 0xB1 | 10  | 1   | 10001 | TCQF Option        |this document|
+------+-----+-----+-------+--------------------+-------------+
]]></artwork></figure>

</section>
<section anchor="acknowledgement"><name>Acknowledgement</name>

<t>Many thanks for review by David Black (DetNet techadvisor). Thanks to
Xiaoliang Zheng and Fan Yang for their input to the TCQF option format.</t>

</section>
<section anchor="changelog"><name>Changelog</name>

<t>[RFC-editor: please remove]</t>

<t>Initial draft name: draft-eckert-detnet-mpls-tc-tcqf</t>

<t>00</t>

<t>Initial version</t>

<t>01</t>

<t>Added new co-author.</t>

<t>Changed Data Model to "Configuration Data Model",</t>

<t>and changed syntax from YANG tree to a non-YANG tree, removed empty section
targeted for YANG model. Reason: the configuration parameters that we need
to specify the forwarding behavior is only a subset of what likely would
be a good YANG model, and any work to define such a YANG model not necessary
to specify the algorithm would be scope creep for this specification. Better
done in a separate YANG document. 
Example additional YANG aspects for such a document are
how to map parameters to configuration/operational space, what additional
operational/monitoring parameter to support and how to map the
YANG objects required into various pre-existing YANG trees.</t>

<t>Improved text in forwarding section, simplified sentences, used simplified
configuration data model.</t>

<t>02</t>

<t>Refresh</t>

<t>03</t>

<t>Added ingress processing, and further implementation considerations.</t>

<t>New draft name: draft-eckert-detnet-tcqf</t>

<t>00</t>

<t>Added text for DSCP based tagging of IP/IPv6 packets, therefore changing the
original, MPLS-only centric scope of the document, necessitating a change
in name and title.</t>

<t>This was triggered by the observation of David Black at the IETF114 DetNet
meeting that with DetNet domains being single administrative domains, it
is not necessary to have standardized (cross administrative domain) DSCP
for the tagging of IP/IP6 packets for TCQF. Instead it is sufficient
to use EXP/LU DSCP code space and assignment of these is a local matter
of a domain as is that of TC values when MPLS is used. Standardized DSCP
in the other hand would have required likely work/oversight by TSVWG.</t>

<t>In any case, the authors feel that with this insight, there is no need to
constrain single-domain definition of TCQF to only MPLS, but instead both
MPLS and IP/IPv6 tagging can be easily specified in this one draft.</t>

<t>01</t>

<t>Added new co-author.</t>

<t>02</t>

<t>Attempt to resolve issues from https://github.com/toerless/detnet/issues/1.</t>

<t><list style="symbols">
  <t>Review from David Black, refine queueing/scheduling of pseudocode/explanation to highlight the non-sequential requirements.</t>
  <t>Comment from Lou Berger re. applicability of controller-plane resulting in new section about controller-plane.</t>
  <t>Reference to CENI chinese validation deployment.</t>
</list></t>

<t>03</t>

<t>Merged draft with draft-yizhou-detnet-ipv6-options-for-cqf-variant-02.</t>

<t>Changed specification to be independent of encapsulation/forwarding plane and moved MPLS and IP/DSCP (from old TCQF draft) and IPv6 with extension header into separate seconds.</t>

<t>Human translation of CENI report, uploaded CENI report with permission from CENI onto web page accessible from outside chinese firewall.</t>

<t>04</t>

<t>Added appendix sections on comparison with CSQF and multi class TCQF</t>

<t>05</t>

<t>Refresh.</t>

<t>06</t>

<t>Refresh.</t>

<t>07</t>

<t>Refresh - still waiting for more discuss of direction in detnet WG.</t>

<t>08</t>

<t>Refresh - still waiting for more discuss of direction in detnet WG.</t>

<t>09</t>

<t>Added section "Solution Scope, Taxonomy and Status for DetNet adoption considerations",
made <xref target="I-D.eckert-detnet-flow-interleaving"/> normative and claim it to be part of the
overall solution.</t>

<t>10, 11</t>

<t>Moved Xiaoliang Zheng and Fan Yang into acknowledgement section. 
Explanation: They where initially listed as co-authors for draft-yizhou-detnet-ipv6-options-for-cqf-variant
which was merged into draft-eckert-detnet-tcqf and at that point in time the
list of authors was simply merged. As part of preparing for possible adoption of
draft-eckert-detnet-tcqf we revisited the amount of participation of the listed
authors and concluded, that the input from Xiaoliang Zheng and Fan Yang
was best met by giving them acknowledgment also noting that they have not
been active in the IETF DetNet work itself.</t>

</section>


  </middle>

  <back>


    <references title='Normative References' anchor="sec-normative-references">



<reference anchor="RFC2474">
  <front>
    <title>Definition of the Differentiated Services Field (DS Field) in the IPv4 and IPv6 Headers</title>
    <author fullname="K. Nichols" initials="K." surname="Nichols"/>
    <author fullname="S. Blake" initials="S." surname="Blake"/>
    <author fullname="F. Baker" initials="F." surname="Baker"/>
    <author fullname="D. Black" initials="D." surname="Black"/>
    <date month="December" year="1998"/>
    <abstract>
      <t>This document defines the IP header field, called the DS (for differentiated services) field. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="2474"/>
  <seriesInfo name="DOI" value="10.17487/RFC2474"/>
</reference>

<reference anchor="RFC3270">
  <front>
    <title>Multi-Protocol Label Switching (MPLS) Support of Differentiated Services</title>
    <author fullname="F. Le Faucheur" initials="F." role="editor" surname="Le Faucheur"/>
    <author fullname="L. Wu" initials="L." surname="Wu"/>
    <author fullname="B. Davie" initials="B." surname="Davie"/>
    <author fullname="S. Davari" initials="S." surname="Davari"/>
    <author fullname="P. Vaananen" initials="P." surname="Vaananen"/>
    <author fullname="R. Krishnan" initials="R." surname="Krishnan"/>
    <author fullname="P. Cheval" initials="P." surname="Cheval"/>
    <author fullname="J. Heinanen" initials="J." surname="Heinanen"/>
    <date month="May" year="2002"/>
    <abstract>
      <t>This document defines a flexible solution for support of Differentiated Services (Diff-Serv) over Multi-Protocol Label Switching (MPLS) networks. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="3270"/>
  <seriesInfo name="DOI" value="10.17487/RFC3270"/>
</reference>

<reference anchor="RFC8655">
  <front>
    <title>Deterministic Networking Architecture</title>
    <author fullname="N. Finn" initials="N." surname="Finn"/>
    <author fullname="P. Thubert" initials="P." surname="Thubert"/>
    <author fullname="B. Varga" initials="B." surname="Varga"/>
    <author fullname="J. Farkas" initials="J." surname="Farkas"/>
    <date month="October" year="2019"/>
    <abstract>
      <t>This document provides the overall architecture for Deterministic Networking (DetNet), which provides a capability to carry specified unicast or multicast data flows for real-time applications with extremely low data loss rates and bounded latency within a network domain. Techniques used include 1) reserving data-plane resources for individual (or aggregated) DetNet flows in some or all of the intermediate nodes along the path of the flow, 2) providing explicit routes for DetNet flows that do not immediately change with the network topology, and 3) distributing data from DetNet flow packets over time and/or space to ensure delivery of each packet's data in spite of the loss of a path. DetNet operates at the IP layer and delivers service over lower-layer technologies such as MPLS and Time- Sensitive Networking (TSN) as defined by IEEE 802.1.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8655"/>
  <seriesInfo name="DOI" value="10.17487/RFC8655"/>
</reference>

<reference anchor="RFC8200">
  <front>
    <title>Internet Protocol, Version 6 (IPv6) Specification</title>
    <author fullname="S. Deering" initials="S." surname="Deering"/>
    <author fullname="R. Hinden" initials="R." surname="Hinden"/>
    <date month="July" year="2017"/>
    <abstract>
      <t>This document specifies version 6 of the Internet Protocol (IPv6). It obsoletes RFC 2460.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="86"/>
  <seriesInfo name="RFC" value="8200"/>
  <seriesInfo name="DOI" value="10.17487/RFC8200"/>
</reference>

<reference anchor="RFC8964">
  <front>
    <title>Deterministic Networking (DetNet) Data Plane: MPLS</title>
    <author fullname="B. Varga" initials="B." role="editor" surname="Varga"/>
    <author fullname="J. Farkas" initials="J." surname="Farkas"/>
    <author fullname="L. Berger" initials="L." surname="Berger"/>
    <author fullname="A. Malis" initials="A." surname="Malis"/>
    <author fullname="S. Bryant" initials="S." surname="Bryant"/>
    <author fullname="J. Korhonen" initials="J." surname="Korhonen"/>
    <date month="January" year="2021"/>
    <abstract>
      <t>This document specifies the Deterministic Networking (DetNet) data plane when operating over an MPLS Packet Switched Network. It leverages existing pseudowire (PW) encapsulations and MPLS Traffic Engineering (MPLS-TE) encapsulations and mechanisms. This document builds on the DetNet architecture and data plane framework.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8964"/>
  <seriesInfo name="DOI" value="10.17487/RFC8964"/>
</reference>


<reference anchor="I-D.eckert-detnet-flow-interleaving">
   <front>
      <title>Deterministic Networking (DetNet) Data Plane - Flow interleaving for scaling detnet data planes with minimal end-to-end latency and large number of flows.</title>
      <author fullname="Toerless Eckert" initials="T. T." surname="Eckert">
         <organization>Futurewei Technologies USA</organization>
      </author>
      <date day="7" month="July" year="2025"/>
      <abstract>
	 <t>   This memo explain requirements, benefits and feasibility of a new
   DetNet service function tentatively called &quot;flow interleaving&quot;.  It
   proposes to introduce this service function into the DetNet
   architecture.

   Flow interleaving can be understood as a DetNet equivalent of the
   IEEE TSN timed gates.  Its primary role is intended to be at the
   ingress edge of DetNet domains supporting higher utilization and
   lower bounded latency for flow aggregation (interleaving of flows
   into a single flow), as well as higher utilization and lower bounded
   latency for interleaving occurring in transit hops of the DetNet
   domain in conjunction with in-time per-hop bounded latency forwarding
   mechanisms.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-eckert-detnet-flow-interleaving-03"/>
   
</reference>




    </references>

    <references title='Informative References' anchor="sec-informative-references">



<reference anchor="RFC3209">
  <front>
    <title>RSVP-TE: Extensions to RSVP for LSP Tunnels</title>
    <author fullname="D. Awduche" initials="D." surname="Awduche"/>
    <author fullname="L. Berger" initials="L." surname="Berger"/>
    <author fullname="D. Gan" initials="D." surname="Gan"/>
    <author fullname="T. Li" initials="T." surname="Li"/>
    <author fullname="V. Srinivasan" initials="V." surname="Srinivasan"/>
    <author fullname="G. Swallow" initials="G." surname="Swallow"/>
    <date month="December" year="2001"/>
    <abstract>
      <t>This document describes the use of RSVP (Resource Reservation Protocol), including all the necessary extensions, to establish label-switched paths (LSPs) in MPLS (Multi-Protocol Label Switching). Since the flow along an LSP is completely identified by the label applied at the ingress node of the path, these paths may be treated as tunnels. A key application of LSP tunnels is traffic engineering with MPLS as specified in RFC 2702. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="3209"/>
  <seriesInfo name="DOI" value="10.17487/RFC3209"/>
</reference>

<reference anchor="RFC4875">
  <front>
    <title>Extensions to Resource Reservation Protocol - Traffic Engineering (RSVP-TE) for Point-to-Multipoint TE Label Switched Paths (LSPs)</title>
    <author fullname="R. Aggarwal" initials="R." role="editor" surname="Aggarwal"/>
    <author fullname="D. Papadimitriou" initials="D." role="editor" surname="Papadimitriou"/>
    <author fullname="S. Yasukawa" initials="S." role="editor" surname="Yasukawa"/>
    <date month="May" year="2007"/>
    <abstract>
      <t>This document describes extensions to Resource Reservation Protocol - Traffic Engineering (RSVP-TE) for the set up of Traffic Engineered (TE) point-to-multipoint (P2MP) Label Switched Paths (LSPs) in Multi- Protocol Label Switching (MPLS) and Generalized MPLS (GMPLS) networks. The solution relies on RSVP-TE without requiring a multicast routing protocol in the Service Provider core. Protocol elements and procedures for this solution are described.</t>
      <t>There can be various applications for P2MP TE LSPs such as IP multicast. Specification of how such applications will use a P2MP TE LSP is outside the scope of this document. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4875"/>
  <seriesInfo name="DOI" value="10.17487/RFC4875"/>
</reference>

<reference anchor="RFC8296">
  <front>
    <title>Encapsulation for Bit Index Explicit Replication (BIER) in MPLS and Non-MPLS Networks</title>
    <author fullname="IJ. Wijnands" initials="IJ." role="editor" surname="Wijnands"/>
    <author fullname="E. Rosen" initials="E." role="editor" surname="Rosen"/>
    <author fullname="A. Dolganow" initials="A." surname="Dolganow"/>
    <author fullname="J. Tantsura" initials="J." surname="Tantsura"/>
    <author fullname="S. Aldrin" initials="S." surname="Aldrin"/>
    <author fullname="I. Meilik" initials="I." surname="Meilik"/>
    <date month="January" year="2018"/>
    <abstract>
      <t>Bit Index Explicit Replication (BIER) is an architecture that provides optimal multicast forwarding through a "multicast domain", without requiring intermediate routers to maintain any per-flow state or to engage in an explicit tree-building protocol. When a multicast data packet enters the domain, the ingress router determines the set of egress routers to which the packet needs to be sent. The ingress router then encapsulates the packet in a BIER header. The BIER header contains a bit string in which each bit represents exactly one egress router in the domain; to forward the packet to a given set of egress routers, the bits corresponding to those routers are set in the BIER header. The details of the encapsulation depend on the type of network used to realize the multicast domain. This document specifies a BIER encapsulation that can be used in an MPLS network or, with slight differences, in a non-MPLS network.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8296"/>
  <seriesInfo name="DOI" value="10.17487/RFC8296"/>
</reference>

<reference anchor="RFC8402">
  <front>
    <title>Segment Routing Architecture</title>
    <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
    <author fullname="S. Previdi" initials="S." role="editor" surname="Previdi"/>
    <author fullname="L. Ginsberg" initials="L." surname="Ginsberg"/>
    <author fullname="B. Decraene" initials="B." surname="Decraene"/>
    <author fullname="S. Litkowski" initials="S." surname="Litkowski"/>
    <author fullname="R. Shakir" initials="R." surname="Shakir"/>
    <date month="July" year="2018"/>
    <abstract>
      <t>Segment Routing (SR) leverages the source routing paradigm. A node steers a packet through an ordered list of instructions, called "segments". A segment can represent any instruction, topological or service based. A segment can have a semantic local to an SR node or global within an SR domain. SR provides a mechanism that allows a flow to be restricted to a specific topological path, while maintaining per-flow state only at the ingress node(s) to the SR domain.</t>
      <t>SR can be directly applied to the MPLS architecture with no change to the forwarding plane. A segment is encoded as an MPLS label. An ordered list of segments is encoded as a stack of labels. The segment to process is on the top of the stack. Upon completion of a segment, the related label is popped from the stack.</t>
      <t>SR can be applied to the IPv6 architecture, with a new type of routing header. A segment is encoded as an IPv6 address. An ordered list of segments is encoded as an ordered list of IPv6 addresses in the routing header. The active segment is indicated by the Destination Address (DA) of the packet. The next active segment is indicated by a pointer in the new routing header.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8402"/>
  <seriesInfo name="DOI" value="10.17487/RFC8402"/>
</reference>

<reference anchor="RFC8938">
  <front>
    <title>Deterministic Networking (DetNet) Data Plane Framework</title>
    <author fullname="B. Varga" initials="B." role="editor" surname="Varga"/>
    <author fullname="J. Farkas" initials="J." surname="Farkas"/>
    <author fullname="L. Berger" initials="L." surname="Berger"/>
    <author fullname="A. Malis" initials="A." surname="Malis"/>
    <author fullname="S. Bryant" initials="S." surname="Bryant"/>
    <date month="November" year="2020"/>
    <abstract>
      <t>This document provides an overall framework for the Deterministic Networking (DetNet) data plane. It covers concepts and considerations that are generally common to any DetNet data plane specification. It describes related Controller Plane considerations as well.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8938"/>
  <seriesInfo name="DOI" value="10.17487/RFC8938"/>
</reference>

<reference anchor="RFC8986">
  <front>
    <title>Segment Routing over IPv6 (SRv6) Network Programming</title>
    <author fullname="C. Filsfils" initials="C." role="editor" surname="Filsfils"/>
    <author fullname="P. Camarillo" initials="P." role="editor" surname="Camarillo"/>
    <author fullname="J. Leddy" initials="J." surname="Leddy"/>
    <author fullname="D. Voyer" initials="D." surname="Voyer"/>
    <author fullname="S. Matsushima" initials="S." surname="Matsushima"/>
    <author fullname="Z. Li" initials="Z." surname="Li"/>
    <date month="February" year="2021"/>
    <abstract>
      <t>The Segment Routing over IPv6 (SRv6) Network Programming framework enables a network operator or an application to specify a packet processing program by encoding a sequence of instructions in the IPv6 packet header.</t>
      <t>Each instruction is implemented on one or several nodes in the network and identified by an SRv6 Segment Identifier in the packet.</t>
      <t>This document defines the SRv6 Network Programming concept and specifies the base set of SRv6 behaviors that enables the creation of interoperable overlays with underlay optimization.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8986"/>
  <seriesInfo name="DOI" value="10.17487/RFC8986"/>
</reference>

<reference anchor="RFC9016">
  <front>
    <title>Flow and Service Information Model for Deterministic Networking (DetNet)</title>
    <author fullname="B. Varga" initials="B." surname="Varga"/>
    <author fullname="J. Farkas" initials="J." surname="Farkas"/>
    <author fullname="R. Cummings" initials="R." surname="Cummings"/>
    <author fullname="Y. Jiang" initials="Y." surname="Jiang"/>
    <author fullname="D. Fedyk" initials="D." surname="Fedyk"/>
    <date month="March" year="2021"/>
    <abstract>
      <t>This document describes the flow and service information model for Deterministic Networking (DetNet). These models are defined for IP and MPLS DetNet data planes.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9016"/>
  <seriesInfo name="DOI" value="10.17487/RFC9016"/>
</reference>

<reference anchor="RFC9320">
  <front>
    <title>Deterministic Networking (DetNet) Bounded Latency</title>
    <author fullname="N. Finn" initials="N." surname="Finn"/>
    <author fullname="J.-Y. Le Boudec" initials="J.-Y." surname="Le Boudec"/>
    <author fullname="E. Mohammadpour" initials="E." surname="Mohammadpour"/>
    <author fullname="J. Zhang" initials="J." surname="Zhang"/>
    <author fullname="B. Varga" initials="B." surname="Varga"/>
    <date month="November" year="2022"/>
    <abstract>
      <t>This document presents a timing model for sources, destinations, and Deterministic Networking (DetNet) transit nodes. Using the model, it provides a methodology to compute end-to-end latency and backlog bounds for various queuing methods. The methodology can be used by the management and control planes and by resource reservation algorithms to provide bounded latency and zero congestion loss for the DetNet service.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9320"/>
  <seriesInfo name="DOI" value="10.17487/RFC9320"/>
</reference>


<reference anchor="I-D.ietf-detnet-dataplane-taxonomy">
   <front>
      <title>Dataplane Enhancement Taxonomy</title>
      <author fullname="Jinoo Joung" initials="J." surname="Joung">
         <organization>Sangmyung University</organization>
      </author>
      <author fullname="Xuesong Geng" initials="X." surname="Geng">
         <organization>Huawei</organization>
      </author>
      <author fullname="Shaofu Peng" initials="S." surname="Peng">
         <organization>ZTE Corporation</organization>
      </author>
      <author fullname="Toerless Eckert" initials="T. T." surname="Eckert">
         <organization>Futurewei Technologies</organization>
      </author>
      <date day="7" month="July" year="2025"/>
      <abstract>
	 <t>   This draft is to facilitate the understanding of the data plane
   enhancement solutions, which are suggested currently or can be
   suggested in the future, for deterministic networking.  This draft
   provides criteria for classifying data plane solutions.  Examples of
   each category are listed, along with reasons where necessary.
   Strengths and limitations of the categories are described.
   Suitability of the solutions for various services of deterministic
   networking are also mentioned.  Reference topologies for evaluation
   of the solutions are given as well.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-detnet-dataplane-taxonomy-04"/>
   
</reference>


<reference anchor="I-D.ietf-bier-te-arch">
   <front>
      <title>Tree Engineering for Bit Index Explicit Replication (BIER-TE)</title>
      <author fullname="Toerless Eckert" initials="T. T." surname="Eckert">
         <organization>Futurewei Technologies Inc.</organization>
      </author>
      <author fullname="Michael Menth" initials="M." surname="Menth">
         <organization>University of Tuebingen</organization>
      </author>
      <author fullname="Gregory Cauchie" initials="G." surname="Cauchie">
         <organization>KOEVOO</organization>
      </author>
      <date day="25" month="April" year="2022"/>
      <abstract>
	 <t>This memo describes per-packet stateless strict and loose path steered replication and forwarding for &quot;Bit Index Explicit Replication&quot; (BIER) packets (RFC 8279); it is called &quot;Tree Engineering for Bit Index Explicit Replication&quot; (BIER-TE) and is intended to be used as the path steering mechanism for Traffic Engineering with BIER.

 BIER-TE introduces a new semantic for &quot;bit positions&quot; (BPs). These BPs indicate adjacencies of the network topology, as opposed to (non-TE) BIER in which BPs indicate &quot;Bit-Forwarding Egress Routers&quot; (BFERs). A BIER-TE &quot;packets BitString&quot; therefore indicates the edges of the (loop-free) tree across which the packets are forwarded by BIER-TE. BIER-TE can leverage BIER forwarding engines with little changes. Co-existence of BIER and BIER-TE forwarding in the same domain is possible -- for example, by using separate BIER &quot;subdomains&quot; (SDs). Except for the optional routed adjacencies, BIER-TE does not require a BIER routing underlay and can therefore operate without depending on a routing protocol such as the &quot;Interior Gateway Protocol&quot; (IGP).
	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-ietf-bier-te-arch-13"/>
   
</reference>


<reference anchor="I-D.eckert-detnet-bounded-latency-problems">
   <front>
      <title>Problems with existing DetNet bounded latency queuing mechanisms</title>
      <author fullname="Toerless Eckert" initials="T. T." surname="Eckert">
         <organization>Futurewei Technologies USA</organization>
      </author>
      <author fullname="Stewart Bryant" initials="S." surname="Bryant">
         <organization>Stewart Bryant Ltd</organization>
      </author>
      <date day="12" month="July" year="2021"/>
      <abstract>
	 <t>   The purpose of this memo is to explain the challenges and limitations
   of existing (standardized) bounded latency queuing mechanisms for
   desirable (large scale) MPLS and/or IP based networks to allow them
   to support DetNet services.  These challenges relate to low-cost,
   high-speed hardware implementations, desirable network design
   approaches, system complexity, reliability, scalability, cost of
   signaling, performance and jitter experience for the DetNet
   applications.  Many of these problems are rooted in the use of per-
   hop, per-flow (DetNet) forwarding and queuing state, but highly
   accurate network wide time synchronization can be another challenge
   for some networks.

   This memo does not intend to propose a specific queuing solution, but
   in the same way in which it describes the challenges of mechanisms,
   it reviews how those problem are addressed by currently proposed new
   queuing mechanisms.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-eckert-detnet-bounded-latency-problems-00"/>
   
</reference>


<reference anchor="I-D.qiang-detnet-large-scale-detnet">
   <front>
      <title>Large-Scale Deterministic IP Network</title>
      <author fullname="Li Qiang" initials="L." surname="Qiang">
         <organization>Huawei</organization>
      </author>
      <author fullname="Xuesong Geng" initials="X." surname="Geng">
         <organization>Huawei</organization>
      </author>
      <author fullname="Bingyang Liu" initials="B." surname="Liu">
         <organization>Huawei</organization>
      </author>
      <author fullname="Toerless Eckert" initials="T. T." surname="Eckert">
         <organization>Huawei</organization>
      </author>
      <author fullname="Liang Geng" initials="L." surname="Geng">
         <organization>China Mobile</organization>
      </author>
      <author fullname="Guangpeng Li" initials="G." surname="Li">
         </author>
      <date day="2" month="September" year="2019"/>
      <abstract>
	 <t>   This document presents the overall framework and key method for
   Large-scale Deterministic Network (LDN).  LDN can provide bounded
   latency and delay variation (jitter) without requiring precise time
   synchronization among nodes, or per-flow state in transit nodes.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-qiang-detnet-large-scale-detnet-05"/>
   
</reference>


<reference anchor="I-D.dang-queuing-with-multiple-cyclic-buffers">
   <front>
      <title>A Queuing Mechanism with Multiple Cyclic Buffers</title>
      <author fullname="Bingyang Liu" initials="B." surname="Liu">
         <organization>Huawei</organization>
      </author>
      <author fullname="Joanna Dang" initials="J." surname="Dang">
         <organization>Huawei</organization>
      </author>
      <date day="22" month="February" year="2021"/>
      <abstract>
	 <t>   This document presents a queuing mechanism with multiple cyclic
   buffers.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-dang-queuing-with-multiple-cyclic-buffers-00"/>
   
</reference>


<reference anchor="I-D.chen-detnet-sr-based-bounded-latency">
   <front>
      <title>Segment Routing (SR) Based Bounded Latency</title>
      <author fullname="Mach Chen" initials="M." surname="Chen">
         <organization>Huawei</organization>
      </author>
      <author fullname="Xuesong Geng" initials="X." surname="Geng">
         <organization>Huawei</organization>
      </author>
      <author fullname="Zhenqiang Li" initials="Z." surname="Li">
         <organization>China Mobile</organization>
      </author>
      <author fullname="Jinoo Joung" initials="J." surname="Joung">
         <organization>Sangmyung University</organization>
      </author>
      <author fullname="Jeong-dong Ryoo" initials="J." surname="Ryoo">
         <organization>ETRI</organization>
      </author>
      <date day="7" month="July" year="2023"/>
      <abstract>
	 <t>   One of the goals of DetNet is to provide bounded end-to-end latency
   for critical flows.  This document defines how to leverage Segment
   Routing (SR) to implement bounded latency.  Specifically, the SR
   Identifier (SID) is used to specify transmission time (cycles) of a
   packet.  When forwarding devices along the path follow the
   instructions carried in the packet, the bounded latency is achieved.
   This is called Cycle Specified Queuing and Forwarding (CSQF) in this
   document.

   Since SR is a source routing technology, no per-flow state is
   maintained at intermediate and egress nodes, SR-based CSQF naturally
   supports flow aggregation that is deemed to be a key capability to
   allow DetNet to scale to large networks.


	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-chen-detnet-sr-based-bounded-latency-03"/>
   
</reference>


<reference anchor="I-D.eckert-detnet-glbf">
   <front>
      <title>Deterministic Networking (DetNet) Data Plane - guaranteed Latency Based Forwarding (gLBF) for bounded latency with low jitter and asynchronous forwarding in Deterministic Networks</title>
      <author fullname="Toerless Eckert" initials="T. T." surname="Eckert">
         <organization>Futurewei Technologies USA</organization>
      </author>
      <author fullname="Alexander Clemm" initials="A." surname="Clemm">
         <organization>Sympotech</organization>
      </author>
      <author fullname="Stewart Bryant" initials="S." surname="Bryant">
         <organization>Independent</organization>
      </author>
      <author fullname="Stefan Hommes" initials="S." surname="Hommes">
         <organization>ZF Friedrichshafen AG</organization>
      </author>
      <date day="11" month="December" year="2025"/>
      <abstract>
	 <t>   This memo proposes a mechanism called &quot;guaranteed Latency Based
   Forwarding&quot; (gLBF) as part of DetNet for hop-by-hop packet forwarding
   with per-hop deterministically bounded latency and minimal jitter.

   gLBF is intended to be useful across a wide range of networks and
   applications with need for high-precision deterministic networking
   services, including in-car networks or networks used for industrial
   automation across on factory floors, all the way to ++100Gbps
   country-wide networks.

   Contrary to other mechanisms, gLBF does not require network wide
   clock synchronization, nor does it need to maintain per-flow state at
   network nodes, avoiding drawbacks of other known methods while
   leveraging their advantages.

   Specifically, gLBF uses the queuing model and calculus of Urgency
   Based Scheduling (UBS, [UBS]), which is used by TSN Asynchronous
   Traffic Shaping [TSN-ATS]. gLBF is intended to be a plug-in
   replacement for TSN-ATN or as a parallel mechanism beside TSN-ATS
   because it allows to keeping the same controller-plane design which
   is selecting paths for TSN-ATS, sizing TSN-ATS queues, calculating
   latencies and admitting flows to calculated paths for calculated
   latencies.

   In addition to reducing the jitter compared to TSN-ATS by additional
   buffering (dampening) in the network, gLBF also eliminates the need
   for per-flow, per-hop state maintenance required by TSN-ATS.  This
   avoids the need to signal per-flow state to every hop from the
   controller-plane and associated scaling problems.  It also reduces
   implementation cost for high-speed networking hardware due to the
   avoidance of additional high-speed speed read/write memory access to
   retrieve, process and update per-flow state variables for a large
   number of flows.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-eckert-detnet-glbf-07"/>
   
</reference>


<reference anchor="CENI" target="https://raw.githubusercontent.com/network2030/publications/main/CENI_DIP_Networking_Test_Report.pdf">
  <front>
    <title>CENI DIP Networking Test Report</title>
    <author >
      <organization>China Environment for Network Innovations (CENI)</organization>
    </author>
    <date year="2020"/>
  </front>
<annotation>Translated with permission from chinese version at: https://ceni.org.cn/406.html</annotation></reference>
<reference anchor="IEEE802.1Q" target="https://doi.org/10.1109/ieeestd.2018.8403927">
  <front>
    <title>IEEE Standard for Local and Metropolitan Area Network — Bridges and Bridged Networks (IEEE Std 802.1Q)</title>
    <author >
      <organization>IEEE 802.1 Working Group</organization>
    </author>
    <date year="2018"/>
  </front>
  <seriesInfo name="doi" value="10.1109/ieeestd.2018.8403927"/>
</reference>
<reference anchor="IEEE802.1Qbv" >
  <front>
    <title>IEEE Standard for Local and metropolitan area networks -- Bridges and Bridged Networks - Amendment 25: Enhancements for Scheduled Traffic</title>
    <author >
      <organization>IEEE Time-Sensitive Networking (TSN) Task Group.</organization>
    </author>
    <date year="2015"/>
  </front>
</reference>
<reference anchor="IEEE802.1Qch" >
  <front>
    <title>IEEE Std 802.1Qch-2017: IEEE Standard for Local and Metropolitan Area Networks - Bridges and Bridged Networks - Amendment 29: Cyclic Queuing and Forwarding</title>
    <author >
      <organization>IEEE Time-Sensitive Networking (TSN) Task Group.</organization>
    </author>
    <date year="2017"/>
  </front>
</reference>
<reference anchor="TSN-ATS" target="https://1.ieee802.org/tsn/802-1qcr/">
  <front>
    <title>P802.1Qcr - Bridges and Bridged Networks Amendment: Asynchronous Traffic Shaping</title>
    <author initials="J." surname="Specht" fullname="Johannes Specht">
      <organization></organization>
    </author>
    <date year="2020" month="July" day="09"/>
  </front>
  <seriesInfo name="IEEE" value=""/>
</reference>
<reference anchor="IPV6-PARMS" target="https://www.iana.org/assignments/ipv6-parameters/ipv6-parameters.xhtml">
  <front>
    <title>Internet Protocol Version 6 (IPv6) Parameters</title>
    <author >
      <organization></organization>
    </author>
    <date year="n.d."/>
  </front>
  <seriesInfo name="IANA" value=""/>
</reference>
<reference anchor="LDN" target="https://dl.ifip.org/db/conf/networking/networking2021/1570696888.pdf">
  <front>
    <title>Towards Large-Scale Deterministic IP Networks</title>
    <author initials="B." surname="Liu" fullname="Binyang Liu">
      <organization></organization>
    </author>
    <author initials="S." surname="Ren" fullname="Shoushou Ren">
      <organization></organization>
    </author>
    <author initials="C." surname="Wang" fullname="Chuang Wang">
      <organization></organization>
    </author>
    <author initials="V." surname="Angilella" fullname="Vincent Angilella">
      <organization></organization>
    </author>
    <author initials="P." surname="Medagliani" fullname="Paolo Medagliani">
      <organization></organization>
    </author>
    <author initials="S." surname="Martin" fullname="Sebastien Martin">
      <organization></organization>
    </author>
    <author initials="J." surname="Leguay" fullname="Jeremie Leguay">
      <organization></organization>
    </author>
    <date year="2021"/>
  </front>
  <seriesInfo name="IEEE" value="2021 IFIP Networking Conference (IFIP Networking)"/>
  <seriesInfo name="doi" value="10.23919/IFIPNetworking52078.2021.9472798"/>
</reference>
<reference anchor="multipleCQF" target="https://www.ieee802.org/1/files/public/docs2021/new-finn-multiple-CQF-0921-v02.pdf">
  <front>
    <title>Multiple Cyclic Queuing and Forwarding</title>
    <author initials="N." surname="Finn" fullname="Norm Finn">
      <organization></organization>
    </author>
    <date year="2021" month="October"/>
  </front>
</reference>


    </references>


<?line 1551?>

<section anchor="csqf"><name>CSQF</name>

<t><xref target="I-D.chen-detnet-sr-based-bounded-latency"/> (CSQF) describes a variation of the cyclic
queuing mechanism in which the cycle identifier is not mapped by a mapping table
in each node (as in TCQF), instead the packet header carries the sequence of cycles for every
cyclic queuing hop. In the draft, this is proposed specifically for networks
using Segment Routing and can therefore allocate for N cycles N SIDs, each one for
a different cycle to allow indicating in a SID sequence header for each hop, which
cycle to use.</t>

<t>The core new functionality enabled with eliminating the cycle mapping table on
the routers and moving the sequence of cycles into the header is the ability to
utilize in a flexible fashion more than a fixed number of cycles, independently on each hop.</t>

<t>Assume a minimum of N (e.g.: N = 3) cycles would be required in a particular deployment
with TCQF. If CSQF is then set up with e.g.: N + 4 = 7 cycles, then it would be
possible for the controller-plane to delay packets of a flow on every hop
by 1,2,3 or 4 more cycles than necessary at minimum. This can lead to an easier
ability to achieve higher utilization in the face of controller-plane operations
that manages large number of flows in large scale DetNets, and does not allocate
to every flow bandwidth in every cycle. This naturally leads to uneven utilization
of cycles and the problem of managing distribution of traffic load across cycles.</t>

<t><xref target="I-D.eckert-detnet-flow-interleaving"/> discusses this overall advanced controller-plane
traffic management and how different queuing options can be used in such a setup. It
also describes the necessary ingress processing to allow forwarding traffic flows
only in such well engineered specific cycles.</t>

<t>While such advanced cycle engineering may look at first quite complex, it should simply
be compared to the mechanisms that already are standard in service provider networks
to manage bandwidth/capacity by engineering per-flow paths across topologies with
non-equal cost paths. In that overall complex problem space, managing distribution
of traffic across cycles is but a minor extension.</t>

<t>Note that TCQF can of course also benefit from such advanced cycle engineering at
the controller plane, albeit less flexibly than CSQF.</t>

<t>Given how CQSF and TCQF share all the forwarding behavior except for where the
cycle Identifier is retrieved from and how it is mapped, it would also be a very
useeful consideration to consider both approaches options of a single target standard.
It seems unlikely though, that an implementation that can support TCQF could not
support CSQF - or vice versa.</t>

</section>
<section anchor="priorities"><name>TCQF with multiple priorities</name>

<t>TSN CQF <xref target="IEEE802.1Qch"/> does permit to establish multiple independent cyclic
queuing instances and therefore create more flexbility.</t>

<t>Consider likewise, that in DetNet,
there are separate packet headers for a packet priority and a cycle identifier.
For each priority, a separate instance of TCQF is established, and the priority
decides which instance of CQF the packet gets processed by, whereas the cycle 
identifier determines the cycle within the TCQF instance.</t>

<t>Consider for example a setup with 4 priorities 1..4. The cycle time for the
highest priority 1 is C. The cycle time for priority 2 is 2 * C, for priority 3
3 * C and for priority 4 4 * C. In queuing, strict priority queuing is used,
packets from a priority 1 cycle queue will always be sent over those from
priorities 2...4, and so on. In result, a flow can now be given one out of
4 priorities, each with an increasing per-hop latency: C (prio 1), 2C (prio 2), 
3C (prio 3), 4C (prio 4). This does of course also require for admission control
to not allow full utilization of the capacity of cycles in each class. In a simple
static splitting of capacity across classes, each cycle of of each priority could for
example be allowed to be utilized up to 25%.</t>

<t>This multi-priority "extension" to TCQF is in this version of the document only
mentioned as an appendix, because it is not clear if this degree of flexibility is
desired in a first-generation target standard for TCQF. Given how both priority and
cycle identifiers are needed, this mechanism would certainly require for both MPLS
and IP/IPv6 a new extension header, such as the one proposed in this document
to carry the Cycle IDentifierm and then the priority could be indicated by the IP
header DSCP.</t>

</section>
<section anchor="tsn-multiple-buffer-cqf"><name>TSN Multiple Buffer CQF</name>

<t>CQF with multiple buffers but without tagging has been proposed to IEEE TSN
in <xref target="multipleCQF"/>, but has not been adopted. Instead of relying on a cycle
tag in a packet header as proposed in this memo, it still relies solely on
the arrival time of packet, and can hence not equally resolve arrival time
ambiguities as TCQF can, because it does not know the cycle from which the packet was sent,
or the cycle for which it is intended.</t>

<t>Consider that multiple buffer CQF is like TCQF, except the cycle id is
missing from the packet that is sent. Upon arrival at the receiving router,
the sending cycle ID has to be determined solely by the time the packet
is received (reception timestamp) because this time is an indicator of the
sending timestamp and hence the sending cycle. The sum of MTIE, processing
variation link propagation latency and other variations from layer 1 and layer
2 processing (forward error correction, retransmissions) is the erorr of
the sending time that the receiving router can determine. As soon as this
error is so large, that the receiving router can not unambiguously determine
a sending cycle, the mechanism does not work anymore. The receiving router can
also not simply assume for a packet to be sent by one of the possible cycles,
because when this is not the actual sending cycle, then such an assumption will
cause possible overruns of cycle buffers and hence failure of admission control
and pckets drop or congestion. In result, multiple buffer CQF without carrying
a target cycle in a packet header seems not feasible to actually solve the
issue or real propagation latency variation in transmission, or the perceived
variation in propagation due to jitter in clocks between adjacend nodes.</t>

<t>https://www.iana.org/assignments/ipv6-parameters/ipv6-parameters.xhtml</t>

</section>


  </back>

<!-- ##markdown-source:
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
Ip8k2oGCPAliHUu4DYfOsUCYmx2TdXsR5DTVgMYVT0dbzy9p/nkpURhAkZUk
GuRNU3LoJ2RdCZPf7kyodXheveRdlGYe4EyT6ZAk+wLhvB+dBK4WC7Zk0aN5
OW/lIh1KdJPInqrTi47n7UHexhdnPjB8We+vs9jWNnj3LsQsvd/hy8gWXi83
s20/1viGrFDz+cWmpVjjVutdznDlfFLGxj8/ejmUcHbvT0kVQvEriaxskSxi
5FMBe9WVPhCBk37EfmzDxZI532neSmqQVLEdUcl9Y6immKQhM7pi0WHt8uRV
mLPUDKBRL5PCJ1qIYS4kQCEPRpJ4lAyr5UXAqXiF1CDEczRt31jOaMu2z2lJ
uLLIsxw3HASFZrUIFqRoNKDpTNA1CDq2gPX0NMleajVG04eYt5Z+YNHi6knh
bDV9n9kHmzDTtatXROlTkpw1JgGjK8TbdiUeP7YCVvWVW7U+lwOJHvreINdo
b0krEiMio4uYhzbbG3d4abZMvBrylxBZzQY2QEedkjYJKdQwefLJfRGsqCFT
LUCvlYh7HBJwaOMjbMaFw4+DeRITCNbnUWm75QHmPDE6hitNu2TDAttaxhJp
ddtHWl0g1QcaaVEkmjdfah64qTvJm1kgPwKuFHdODLxhO74qiC0TS0PQ1Ayq
7sjEKOnYBGbx1yxDqvWhVVVez7Nd5lXLMJKAzWE8MttIgqlUjFu5pcYhEYOu
p7qOYFXSmcywuQB/cjmM05MiXjSiy+G4YP3fh3rH20sdrs6Hyi4h9cAdIxbK
+VV+DVc0x1dzEt+qyxKXiNhT3AQ1eio1qfwf5f9zKv8iUN/4aYvyL0L8jZ8+
35w3KP+ZfLodw2kzFH+9+dPWN6Gyk7J+06ebzhX2ge2f+m/2Pn8UUq+dc1/x
TIJqbvp0k2Jvp7r9U2qQ+Cxzf1jBv/3vqOD/u77ZO/hffyNubJlr++38lPVv
pw4pPftfsJYsoSHZR5kEbptJ4JQlgNQQ8CIIKZF80EbpTBrB7j0YIZ3Ic3rv
6Izlqiy4JmJGGoUBgKOKV9WJDMASQyo29d5hLSlHRQ8WOUoRiS+QgVc5v8Tg
IORCHqKD7MQZTEFDGUa+KngTztWdP3Qbk6KjYUkO01y0F+qe5ETOI1vrU053
GmUvTo+eihyTBqX5fC3aZlWQtkGb4wwQ71Of+qyESe1dko5h0wMq7Vgl1GeW
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
Ztw0AQA=

-->

</rfc>

