]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
network: TC - introduce pfifo_head_drop
authorSusant Sahani <ssahani@vmware.com>
Tue, 10 Mar 2020 12:19:56 +0000 (13:19 +0100)
committerYu Watanabe <watanabe.yu+github@gmail.com>
Thu, 12 Mar 2020 06:37:17 +0000 (15:37 +0900)
This adds the required changes to gain access to
the head drop classfull queuing discipline named
pfifo_head_drop.

man/systemd.network.xml
src/network/networkd-network-gperf.gperf
src/network/networkd-network.c
src/network/tc/fifo.c
src/network/tc/fifo.h
src/network/tc/qdisc.c
src/network/tc/qdisc.h
test/fuzz/fuzz-network-parser/directives.network

index 6d90c215ab0467d8de73aa9903e3aafdc09df889..c6997f14206d70bbc61f63d113bfc869a8d49e75 100644 (file)
     </variablelist>
   </refsect1>
 
+  <refsect1>
+    <title>[PFIFOHeadDrop] Section Options</title>
+    <para>The <literal>[PFIFOHeadDrop]</literal> section manages the queueing discipline (qdisc) of
+    Packet First In First Out Head Drop (pfifo_head_drop).</para>
+
+    <variablelist class='network-directives'>
+      <varlistentry>
+        <term><varname>Parent=</varname></term>
+        <listitem>
+          <para>As in <literal>[PFIFO]</literal> section.</para></listitem>
+      </varlistentry>
+
+      <varlistentry>
+        <term><varname>Handle=</varname></term>
+        <listitem>
+          <para>As in <literal>[PFIFO]</literal> section..</para>
+        </listitem>
+      </varlistentry>
+
+      <varlistentry>
+        <term><varname>PacketLimit=</varname></term>
+        <listitem>
+          <para>As in <literal>[PFIFO]</literal> section.</para></listitem>
+      </varlistentry>
+    </variablelist>
+  </refsect1>
+
   <refsect1>
     <title>[CAKE] Section Options</title>
     <para>The <literal>[CAKE]</literal> section manages the queueing discipline (qdisc) of
index 223d245a0f5281677f7d407cd26a8e3b9721fab1..0e8ecabc670aa43c347718845dd028b1417b9449 100644 (file)
@@ -280,6 +280,9 @@ DeficitRoundRobinSchedulerClass.Quantum,     config_parse_drr_size,
 PFIFO.Parent,                                config_parse_qdisc_parent,                                QDISC_KIND_PFIFO,              0
 PFIFO.Handle,                                config_parse_qdisc_handle,                                QDISC_KIND_PFIFO,              0
 PFIFO.PacketLimit,                           config_parse_pfifo_size,                                  QDISC_KIND_PFIFO,              0
+PFIFOHeadDrop.Parent,                        config_parse_qdisc_parent,                                QDISC_KIND_PFIFO_HEAD_DROP,    0
+PFIFOHeadDrop.Handle,                        config_parse_qdisc_handle,                                QDISC_KIND_PFIFO_HEAD_DROP,    0
+PFIFOHeadDrop.PacketLimit,                   config_parse_pfifo_size,                                  QDISC_KIND_PFIFO_HEAD_DROP,    0
 FairQueueing.Parent,                         config_parse_qdisc_parent,                                QDISC_KIND_FQ,                 0
 FairQueueing.Handle,                         config_parse_qdisc_handle,                                QDISC_KIND_FQ,                 0
 FairQueueing.PacketLimit,                    config_parse_fair_queueing_u32,                           QDISC_KIND_FQ,                 0
index 6e4eb39f86f216bf7f38b8f3c862b3bf17d3e350..6b1f00c099932b06d039081f97aee4ddedbd68aa 100644 (file)
@@ -492,6 +492,7 @@ int network_load_one(Manager *manager, OrderedHashmap **networks, const char *fi
                               "DeficitRoundRobinScheduler\0"
                               "DeficitRoundRobinSchedulerClass\0"
                               "PFIFO\0"
+                              "PFIFOHeadDrop\0"
                               "FairQueueing\0"
                               "FairQueueingControlledDelay\0"
                               "GenericRandomEarlyDetection\0"
index 7978f7b9223db07b284fd3ea86011eda4c25390d..a524b614b969e7a6d1c53539cf9125390df1c5f4 100644 (file)
@@ -26,6 +26,9 @@ static int fifo_fill_message(Link *link, QDisc *qdisc, sd_netlink_message *req)
         case QDISC_KIND_BFIFO:
                 fifo = BFIFO(qdisc);
                 break;
+        case QDISC_KIND_PFIFO_HEAD_DROP:
+                fifo = PFIFO_HEAD_DROP(qdisc);
+                break;
         default:
                 assert_not_reached("Invalid QDisc kind.");
         }
@@ -61,14 +64,23 @@ int config_parse_pfifo_size(
         assert(rvalue);
         assert(data);
 
-        r = qdisc_new_static(QDISC_KIND_PFIFO, network, filename, section_line, &qdisc);
+        r = qdisc_new_static(ltype, network, filename, section_line, &qdisc);
         if (r == -ENOMEM)
                 return log_oom();
         if (r < 0)
                 return log_syntax(unit, LOG_ERR, filename, line, r,
                                   "More than one kind of queueing discipline, ignoring assignment: %m");
 
-        fifo = PFIFO(qdisc);
+        switch(qdisc->kind) {
+        case QDISC_KIND_PFIFO:
+                fifo = PFIFO(qdisc);
+                break;
+        case QDISC_KIND_PFIFO_HEAD_DROP:
+                fifo = PFIFO_HEAD_DROP(qdisc);
+                break;
+        default:
+                assert_not_reached("Invalid QDisc kind.");
+        }
 
         if (isempty(rvalue)) {
                 fifo->limit = 0;
@@ -147,7 +159,6 @@ int config_parse_bfifo_size(
         return 0;
 }
 
-
 const QDiscVTable pfifo_vtable = {
         .object_size = sizeof(FirstInFirstOut),
         .tca_kind = "pfifo",
@@ -159,3 +170,9 @@ const QDiscVTable bfifo_vtable = {
        .tca_kind = "bfifo",
        .fill_message = fifo_fill_message,
 };
+
+const QDiscVTable pfifo_head_drop_vtable = {
+       .object_size = sizeof(FirstInFirstOut),
+       .tca_kind = "pfifo_head_drop",
+       .fill_message = fifo_fill_message,
+};
index 7e6a94f16cf9dbb8670963f2286b2dd60205d990..bba5f17abefba7fabb74aee0c883d301edabcf84 100644 (file)
@@ -13,9 +13,11 @@ typedef struct FirstInFirstOut {
 
 DEFINE_QDISC_CAST(PFIFO, FirstInFirstOut);
 DEFINE_QDISC_CAST(BFIFO, FirstInFirstOut);
+DEFINE_QDISC_CAST(PFIFO_HEAD_DROP, FirstInFirstOut);
 
 extern const QDiscVTable pfifo_vtable;
 extern const QDiscVTable bfifo_vtable;
+extern const QDiscVTable pfifo_head_drop_vtable;
 
 CONFIG_PARSER_PROTOTYPE(config_parse_pfifo_size);
 CONFIG_PARSER_PROTOTYPE(config_parse_bfifo_size);
index b6acc29f111515b7b3591a95125a5db13e6de391..da0f43f7d2a602cd02629bd76fb0095242661527 100644 (file)
@@ -27,6 +27,7 @@ const QDiscVTable * const qdisc_vtable[_QDISC_KIND_MAX] = {
         [QDISC_KIND_NETEM] = &netem_vtable,
         [QDISC_KIND_PIE] = &pie_vtable,
         [QDISC_KIND_PFIFO] = &pfifo_vtable,
+        [QDISC_KIND_PFIFO_HEAD_DROP] = &pfifo_head_drop_vtable,
         [QDISC_KIND_SFB] = &sfb_vtable,
         [QDISC_KIND_SFQ] = &sfq_vtable,
         [QDISC_KIND_TBF] = &tbf_vtable,
index 31a3ca34142dd765441f6d74d87afb8ad8eab5c8..8f348d69e3eea2e6e4c0452742295a4038cc1e7a 100644 (file)
@@ -19,6 +19,7 @@ typedef enum QDiscKind {
         QDISC_KIND_HTB,
         QDISC_KIND_NETEM,
         QDISC_KIND_PFIFO,
+        QDISC_KIND_PFIFO_HEAD_DROP,
         QDISC_KIND_PIE,
         QDISC_KIND_SFB,
         QDISC_KIND_SFQ,
index c4d13a73dc7ab0aa6ca067d76ae7cb578d240d88..c0f71bc13f74e6967f6b1d18a456c52b748b6638 100644 (file)
@@ -364,6 +364,10 @@ LimitSize=
 Parent=
 Handle=
 PacketLimit=
+[PFIFOHeadDrop]
+Parent=
+Handle=
+PacketLimit=
 [GenericRandomEarlyDetection]
 Parent=
 Handle=