<?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-07" 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>
    <author initials="F." surname="Yang" fullname="Fan Yang">
      <organization>Huawei Technologies</organization>
      <address>
        <postal>
          <city>Beijing</city>
          <country>China</country>
        </postal>
        <email>shirley.yangfan@huawei.com</email>
      </address>
    </author>

    <date year="2025" month="March" day="03"/>

    
    <workgroup>DETNET</workgroup>
    

    <abstract>


<?line 178?>

<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 188?>

<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="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).</t>

</section>
<section anchor="contributors"><name>Contributors</name>

<t>The following co-authors have contributed to this document.</t>

<t>Xiaoliang Zheng Huawei Email: zhengxiaoliang@huawei.com</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>

</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>




    </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-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-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="2024"/>
      <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-02"/>
   
</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 1478?>

<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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
JgEA

-->

</rfc>

