From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mails.dpdk.org (mails.dpdk.org [217.70.189.124]) by inbox.dpdk.org (Postfix) with ESMTP id 14C98A0547; Fri, 10 Sep 2021 14:33:03 +0200 (CEST) Received: from [217.70.189.124] (localhost [127.0.0.1]) by mails.dpdk.org (Postfix) with ESMTP id 34D8B411C8; Fri, 10 Sep 2021 14:30:52 +0200 (CEST) Received: from mga01.intel.com (mga01.intel.com [192.55.52.88]) by mails.dpdk.org (Postfix) with ESMTP id 3FBB941153 for ; Fri, 10 Sep 2021 14:30:27 +0200 (CEST) X-IronPort-AV: E=McAfee;i="6200,9189,10102"; a="243386318" X-IronPort-AV: E=Sophos;i="5.85,282,1624345200"; d="scan'208";a="243386318" Received: from orsmga001.jf.intel.com ([10.7.209.18]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Sep 2021 05:30:21 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.85,282,1624345200"; d="scan'208";a="514279820" Received: from silpixa00400573.ir.intel.com (HELO silpixa00400573.ger.corp.intel.com) ([10.237.223.107]) by orsmga001.jf.intel.com with ESMTP; 10 Sep 2021 05:30:21 -0700 From: Cristian Dumitrescu To: dev@dpdk.org Date: Fri, 10 Sep 2021 13:29:58 +0100 Message-Id: <20210910123003.85448-19-cristian.dumitrescu@intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210910123003.85448-1-cristian.dumitrescu@intel.com> References: <20210910123003.85448-1-cristian.dumitrescu@intel.com> Subject: [dpdk-dev] [PATCH 19/24] pipeline: introduce pipeline compilation X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" Lay the foundation to generate C code for the pipeline: C functions for actions and custom instructions are generated, built as shared object library and loaded into the pipeline. Signed-off-by: Cristian Dumitrescu --- lib/pipeline/rte_swx_pipeline.c | 44 +++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/lib/pipeline/rte_swx_pipeline.c b/lib/pipeline/rte_swx_pipeline.c index 598009c024..4c0e3043ec 100644 --- a/lib/pipeline/rte_swx_pipeline.c +++ b/lib/pipeline/rte_swx_pipeline.c @@ -8953,6 +8953,9 @@ rte_swx_pipeline_instructions_config(struct rte_swx_pipeline *p, return 0; } +static int +pipeline_compile(struct rte_swx_pipeline *p); + int rte_swx_pipeline_build(struct rte_swx_pipeline *p) { @@ -9018,6 +9021,9 @@ rte_swx_pipeline_build(struct rte_swx_pipeline *p) goto error; p->build_done = 1; + + pipeline_compile(p); + return 0; error: @@ -9760,3 +9766,41 @@ rte_swx_ctl_meter_stats_read(struct rte_swx_pipeline *p, return 0; } + +/* + * Pipeline compilation. + */ +static int +pipeline_codegen(struct rte_swx_pipeline *p) +{ + FILE *f = NULL; + + if (!p) + return -EINVAL; + + /* Create the .c file. */ + f = fopen("/tmp/pipeline.c", "w"); + if (!f) + return -EIO; + + /* Include the .h file. */ + fprintf(f, "#include \"rte_swx_pipeline_internal.h\"\n"); + + /* Close the .c file. */ + fclose(f); + + return 0; +} + +static int +pipeline_compile(struct rte_swx_pipeline *p) +{ + int status = 0; + + /* Code generation. */ + status = pipeline_codegen(p); + if (status) + return status; + + return status; +} -- 2.17.1