Acked-by: Nithin Dabilpuram <ndabilpu...@marvell.com>

On Wed, May 31, 2023 at 5:08 PM Amit Prakash Shukla
<amitpraka...@marvell.com> wrote:
>
> From: Sunil Kumar Kori <sk...@marvell.com>
>
> Similar to ipv4, to support IPv6 lookup and rewrite node
> routes and rewrite data needs to be added.
>
> Patch adds routes for ipv6 to validate ip6_lookup node
> and  rewrite data to validate ip6_rewrite node.
>
> Signed-off-by: Sunil Kumar Kori <sk...@marvell.com>
> Signed-off-by: Amit Prakash Shukla <amitpraka...@marvell.com>
> ---
> v2:
> - Performance related changes
>
> v3:
> - Removing redundant dynamic variable
>
>  doc/guides/sample_app_ug/l3_forward_graph.rst | 40 ++++++----
>  examples/l3fwd-graph/main.c                   | 77 ++++++++++++++++++-
>  2 files changed, 98 insertions(+), 19 deletions(-)
>
> diff --git a/doc/guides/sample_app_ug/l3_forward_graph.rst 
> b/doc/guides/sample_app_ug/l3_forward_graph.rst
> index 585ac8c898..23f86e4785 100644
> --- a/doc/guides/sample_app_ug/l3_forward_graph.rst
> +++ b/doc/guides/sample_app_ug/l3_forward_graph.rst
> @@ -12,7 +12,8 @@ Overview
>  --------
>
>  The application demonstrates the use of the graph framework and graph nodes
> -``ethdev_rx``, ``ip4_lookup``, ``ip4_rewrite``, ``ethdev_tx`` and 
> ``pkt_drop`` in DPDK to
> +``ethdev_rx``, ``pkt_cls``, ``ip4_lookup``/``ip6_lookup``,
> +``ip4_rewrite``/``ip6_rewrite``, ``ethdev_tx`` and ``pkt_drop`` in DPDK to
>  implement packet forwarding.
>
>  The initialization is very similar to those of the :doc:`l3_forward`.
> @@ -24,13 +25,15 @@ TTL update and finally Tx is implemented inside graph 
> nodes. These nodes are
>  interconnected in graph framework. Application main loop needs to walk over
>  graph using ``rte_graph_walk()`` with graph objects created one per worker 
> lcore.
>
> -The lookup method is as per implementation of ``ip4_lookup`` graph node.
> +The lookup method is as per implementation of ``ip4_lookup``/``ip6_lookup`` 
> graph node.
>  The ID of the output interface for the input packet is the next hop returned 
> by
>  the LPM lookup. The set of LPM rules used by the application is statically
> -configured and provided to ``ip4_lookup`` graph node and ``ip4_rewrite`` 
> graph node
> -using node control API ``rte_node_ip4_route_add()`` and 
> ``rte_node_ip4_rewrite_add()``.
> +configured and provided to ``ip4_lookup``/``ip6_lookup`` graph node and
> +``ip4_rewrite``/``ip6_rewrite`` graph node using node control API
> +``rte_node_ip4_route_add()``/``rte_node_ip6_route_add`` and
> +``rte_node_ip4_rewrite_add()``/``rte_node_ip6_rewrite_add``.
>
> -In the sample application, only IPv4 forwarding is supported as of now.
> +In the sample application, IPv4 and IPv6 forwarding is supported.
>
>  Compiling the Application
>  -------------------------
> @@ -149,8 +152,8 @@ lead to the clone of ``ethdev_rx`` and ``ethdev_tx`` 
> nodes as ``ethdev_rx-X-Y``
>  In case of ``ethdev_tx-X`` nodes, tx queue id assigned per instance of the 
> node
>  is same as graph id.
>
> -These cloned nodes along with existing static nodes such as ``ip4_lookup`` 
> and
> -``ip4_rewrite`` will be used in graph creation to associate node's to lcore
> +These cloned nodes along with existing static nodes such as 
> ``ip4_lookup``/``ip6_lookup``
> +and ``ip4_rewrite``/``ip6_rewrite`` will be used in graph creation to 
> associate node's to lcore
>  specific graph object.
>
>  .. literalinclude:: ../../../examples/l3fwd-graph/main.c
> @@ -186,20 +189,21 @@ Forwarding data(Route, Next-Hop) addition
>  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
>
>  Once graph objects are created, node specific info like routes and rewrite
> -headers will be provided run-time using ``rte_node_ip4_route_add()`` and
> -``rte_node_ip4_rewrite_add()`` API.
> +headers will be provided run-time using ``rte_node_ip4_route_add()``/
> +``rte_node_ip6_route_add`` and 
> ``rte_node_ip4_rewrite_add()``/``rte_node_ip6_rewrite_add``
> +API.
>
>  .. note::
>
> -    Since currently ``ip4_lookup`` and ``ip4_rewrite`` nodes don't support
> -    lock-less mechanisms(RCU, etc) to add run-time forwarding data like 
> route and
> -    rewrite data, forwarding data is added before packet processing loop is
> -    launched on worker lcore.
> +    Since currently ``ip4_lookup``/``ip6_lookup`` and 
> ``ip4_rewrite``/``ip6_rewrite``
> +    nodes don't support lock-less mechanisms(RCU, etc) to add run-time 
> forwarding
> +    data like route and rewrite data, forwarding data is added before packet
> +    processing loop is launched on worker lcore.
>
>  .. literalinclude:: ../../../examples/l3fwd-graph/main.c
>      :language: c
> -    :start-after: Add route to ip4 graph infra. 8<
> -    :end-before: >8 End of adding route to ip4 graph infa.
> +    :start-after: Add routes and rewrite data to graph infra. 8<
> +    :end-before: >8 End of adding routes and rewrite data to graph infa.
>      :dedent: 1
>
>  Packet Forwarding using Graph Walk
> @@ -215,8 +219,10 @@ specific graph object that was already created.
>
>      rte_graph_walk() will walk over all the sources nodes i.e 
> ``ethdev_rx-X-Y``
>      associated with a given graph and Rx the available packets and enqueue 
> them
> -    to the following node ``ip4_lookup`` which then will enqueue them to 
> ``ip4_rewrite``
> -    node if LPM lookup succeeds. ``ip4_rewrite`` node then will update 
> Ethernet header
> +    to the following node ``pkt_cls`` which based on the packet type will 
> enqueue
> +    them to ``ip4_lookup``/``ip6_lookup`` which then will enqueue them to
> +    ``ip4_rewrite``/``ip6_rewrite`` node if LPM lookup succeeds.
> +    ``ip4_rewrite``/``ip6_rewrite`` node then will update Ethernet header
>      as per next-hop data and transmit the packet via port 'Z' by enqueuing
>      to ``ethdev_tx-Z`` node instance in its graph object.
>
> diff --git a/examples/l3fwd-graph/main.c b/examples/l3fwd-graph/main.c
> index 5feeab4f0f..0c82e24513 100644
> --- a/examples/l3fwd-graph/main.c
> +++ b/examples/l3fwd-graph/main.c
> @@ -27,9 +27,11 @@
>  #include <rte_launch.h>
>  #include <rte_lcore.h>
>  #include <rte_log.h>
> +#include <rte_lpm6.h>
>  #include <rte_mempool.h>
>  #include <rte_node_eth_api.h>
>  #include <rte_node_ip4_api.h>
> +#include <rte_node_ip6_api.h>
>  #include <rte_per_lcore.h>
>  #include <rte_string_fns.h>
>  #include <rte_vect.h>
> @@ -142,6 +144,12 @@ struct ipv4_l3fwd_lpm_route {
>         uint8_t if_out;
>  };
>
> +struct ipv6_l3fwd_lpm_route {
> +       uint8_t ip[RTE_LPM6_IPV6_ADDR_SIZE];
> +       uint8_t depth;
> +       uint8_t if_out;
> +};
> +
>  #define IPV4_L3FWD_LPM_NUM_ROUTES                                            
>   \
>         (sizeof(ipv4_l3fwd_lpm_route_array) /                                 
>  \
>          sizeof(ipv4_l3fwd_lpm_route_array[0]))
> @@ -153,6 +161,28 @@ static struct ipv4_l3fwd_lpm_route 
> ipv4_l3fwd_lpm_route_array[] = {
>         {RTE_IPV4(198, 18, 6, 0), 24, 6}, {RTE_IPV4(198, 18, 7, 0), 24, 7},
>  };
>
> +#define IPV6_L3FWD_LPM_NUM_ROUTES                                            
>   \
> +       (sizeof(ipv6_l3fwd_lpm_route_array) /                                 
>  \
> +        sizeof(ipv6_l3fwd_lpm_route_array[0]))
> +static struct ipv6_l3fwd_lpm_route ipv6_l3fwd_lpm_route_array[] = {
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x00}, 48, 0},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x01}, 48, 1},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x02}, 48, 2},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x03}, 48, 3},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x04}, 48, 4},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x05}, 48, 5},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x06}, 48, 6},
> +       {{0x20, 0x01, 0xdb, 0x08, 0x12, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 
> 0x00, 0x00, 0x00, 0x00,
> +       0x02}, 48, 7},
> +};
> +
>  static int
>  check_lcore_params(void)
>  {
> @@ -1128,7 +1158,7 @@ main(int argc, char **argv)
>         memset(&rewrite_data, 0, sizeof(rewrite_data));
>         rewrite_len = sizeof(rewrite_data);
>
> -       /* Add route to ip4 graph infra. 8< */
> +       /* Add routes and rewrite data to graph infra. 8< */
>         for (i = 0; i < IPV4_L3FWD_LPM_NUM_ROUTES; i++) {
>                 char route_str[INET6_ADDRSTRLEN * 4];
>                 char abuf[INET6_ADDRSTRLEN];
> @@ -1172,7 +1202,50 @@ main(int argc, char **argv)
>                 RTE_LOG(INFO, L3FWD_GRAPH, "Added route %s, next_hop %u\n",
>                         route_str, i);
>         }
> -       /* >8 End of adding route to ip4 graph infa. */
> +
> +       for (i = 0; i < IPV6_L3FWD_LPM_NUM_ROUTES; i++) {
> +               char route_str[INET6_ADDRSTRLEN * 4];
> +               char abuf[INET6_ADDRSTRLEN];
> +               struct in6_addr in6;
> +               uint32_t dst_port;
> +
> +               /* Skip unused ports */
> +               if ((1 << ipv6_l3fwd_lpm_route_array[i].if_out &
> +                    enabled_port_mask) == 0)
> +                       continue;
> +
> +               dst_port = ipv6_l3fwd_lpm_route_array[i].if_out;
> +
> +               memcpy(in6.s6_addr, ipv6_l3fwd_lpm_route_array[i].ip, 
> RTE_LPM6_IPV6_ADDR_SIZE);
> +               snprintf(route_str, sizeof(route_str), "%s / %d (%d)",
> +                        inet_ntop(AF_INET6, &in6, abuf, sizeof(abuf)),
> +                        ipv6_l3fwd_lpm_route_array[i].depth,
> +                        ipv6_l3fwd_lpm_route_array[i].if_out);
> +
> +               /* Use route index 'i' as next hop id */
> +               ret = rte_node_ip6_route_add(ipv6_l3fwd_lpm_route_array[i].ip,
> +                       ipv6_l3fwd_lpm_route_array[i].depth, i,
> +                       RTE_NODE_IP6_LOOKUP_NEXT_REWRITE);
> +
> +               if (ret < 0)
> +                       rte_exit(EXIT_FAILURE,
> +                                "Unable to add ip6 route %s to graph\n",
> +                                route_str);
> +
> +               memcpy(rewrite_data, val_eth + dst_port, rewrite_len);
> +
> +               /* Add next hop rewrite data for id 'i' */
> +               ret = rte_node_ip6_rewrite_add(i, rewrite_data,
> +                                              rewrite_len, dst_port);
> +               if (ret < 0)
> +                       rte_exit(EXIT_FAILURE,
> +                                "Unable to add next hop %u for "
> +                                "route %s\n", i, route_str);
> +
> +               RTE_LOG(INFO, L3FWD_GRAPH, "Added route %s, next_hop %u\n",
> +                       route_str, i);
> +       }
> +       /* >8 End of adding routes and rewrite data to graph infa. */
>
>         /* Launch per-lcore init on every worker lcore */
>         rte_eal_mp_remote_launch(graph_main_loop, NULL, SKIP_MAIN);
> --
> 2.25.1
>

Reply via email to