Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/58878/?format=api
http://patches.dpdk.org/api/patches/58878/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/20190906131256.23367-2-akhil.goyal@nxp.com/", "project": { "id": 1, "url": "http://patches.dpdk.org/api/projects/1/?format=api", "name": "DPDK", "link_name": "dpdk", "list_id": "dev.dpdk.org", "list_email": "dev@dpdk.org", "web_url": "http://core.dpdk.org", "scm_url": "git://dpdk.org/dpdk", "webscm_url": "http://git.dpdk.org/dpdk", "list_archive_url": "https://inbox.dpdk.org/dev", "list_archive_url_format": "https://inbox.dpdk.org/dev/{}", "commit_url_format": "" }, "msgid": "<20190906131256.23367-2-akhil.goyal@nxp.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20190906131256.23367-2-akhil.goyal@nxp.com", "date": "2019-09-06T13:12:56", "name": "[2/2] event/dpaa: support event crypto adapter", "commit_ref": null, "pull_url": null, "state": "changes-requested", "archived": true, "hash": "508c61ea8e61685e06810beb6e71a041cb5c91ed", "submitter": { "id": 517, "url": "http://patches.dpdk.org/api/people/517/?format=api", "name": "Akhil Goyal", "email": "akhil.goyal@nxp.com" }, "delegate": { "id": 310, "url": "http://patches.dpdk.org/api/users/310/?format=api", "username": "jerin", "first_name": "Jerin", "last_name": "Jacob", "email": "jerinj@marvell.com" }, "mbox": "http://patches.dpdk.org/project/dpdk/patch/20190906131256.23367-2-akhil.goyal@nxp.com/mbox/", "series": [ { "id": 6307, "url": "http://patches.dpdk.org/api/series/6307/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=6307", "date": "2019-09-06T13:12:55", "name": "[1/2] crypto/dpaa_sec: support event crypto adapter", "version": 1, "mbox": "http://patches.dpdk.org/series/6307/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/58878/comments/", "check": "success", "checks": "http://patches.dpdk.org/api/patches/58878/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<dev-bounces@dpdk.org>", "X-Original-To": "patchwork@dpdk.org", "Delivered-To": "patchwork@dpdk.org", "Received": [ "from [92.243.14.124] (localhost [127.0.0.1])\n\tby dpdk.org (Postfix) with ESMTP id 450941F421;\n\tFri, 6 Sep 2019 15:27:26 +0200 (CEST)", "from inva021.nxp.com (inva021.nxp.com [92.121.34.21])\n\tby dpdk.org (Postfix) with ESMTP id 9A2AB1F410\n\tfor <dev@dpdk.org>; Fri, 6 Sep 2019 15:27:23 +0200 (CEST)", "from inva021.nxp.com (localhost [127.0.0.1])\n\tby inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id 7C0562002F0;\n\tFri, 6 Sep 2019 15:27:23 +0200 (CEST)", "from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com\n\t[165.114.16.14])\n\tby inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id AA09D2001AF;\n\tFri, 6 Sep 2019 15:27:20 +0200 (CEST)", "from GDB1.ap.freescale.net (GDB1.ap.freescale.net [10.232.132.179])\n\tby invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 07487402B4;\n\tFri, 6 Sep 2019 21:27:16 +0800 (SGT)" ], "From": "Akhil Goyal <akhil.goyal@nxp.com>", "To": "dev@dpdk.org", "Cc": "hemant.agrawal@nxp.com, anoobj@marvell.com, jerinj@marvell.com,\n\tAkhil Goyal <akhil.goyal@nxp.com>", "Date": "Fri, 6 Sep 2019 18:42:56 +0530", "Message-Id": "<20190906131256.23367-2-akhil.goyal@nxp.com>", "X-Mailer": "git-send-email 2.17.1", "In-Reply-To": "<20190906131256.23367-1-akhil.goyal@nxp.com>", "References": "<20190906131256.23367-1-akhil.goyal@nxp.com>", "X-Virus-Scanned": "ClamAV using ClamSMTP", "Subject": "[dpdk-dev] [PATCH 2/2] event/dpaa: support event crypto adapter", "X-BeenThere": "dev@dpdk.org", "X-Mailman-Version": "2.1.15", "Precedence": "list", "List-Id": "DPDK patches and discussions <dev.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n\t<mailto:dev-request@dpdk.org?subject=unsubscribe>", "List-Archive": "<http://mails.dpdk.org/archives/dev/>", "List-Post": "<mailto:dev@dpdk.org>", "List-Help": "<mailto:dev-request@dpdk.org?subject=help>", "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n\t<mailto:dev-request@dpdk.org?subject=subscribe>", "Errors-To": "dev-bounces@dpdk.org", "Sender": "\"dev\" <dev-bounces@dpdk.org>" }, "content": "event dpaa device support both ethernet as well as\ncrypto queues to be attached to it. eth_rx_adapter\nprovide infrastructure to attach ethernet queues and\ncrypto_adapter provide support for crypto queues.\n\nThis patch add support for dpaa_eventdev to attach\ndpaa_sec queues.\n\nSigned-off-by: Akhil Goyal <akhil.goyal@nxp.com>\n---\n drivers/event/dpaa/Makefile | 3 +\n drivers/event/dpaa/dpaa_eventdev.c | 154 ++++++++++++++++++++++++++++-\n drivers/event/dpaa/dpaa_eventdev.h | 5 +\n 3 files changed, 161 insertions(+), 1 deletion(-)", "diff": "diff --git a/drivers/event/dpaa/Makefile b/drivers/event/dpaa/Makefile\nindex cf9626495..1856fa468 100644\n--- a/drivers/event/dpaa/Makefile\n+++ b/drivers/event/dpaa/Makefile\n@@ -21,6 +21,9 @@ CFLAGS += -I$(RTE_SDK)/drivers/bus/dpaa/include/\n CFLAGS += -I$(RTE_SDK)/drivers/mempool/dpaa\n CFLAGS += -I$(RTE_SDK)/lib/librte_eal/common/include\n \n+LDLIBS += -lrte_pmd_dpaa_sec\n+CFLAGS += -I$(RTE_SDK)/drivers/crypto/dpaa_sec\n+\n EXPORT_MAP := rte_pmd_dpaa_event_version.map\n \n LIBABIVER := 1\ndiff --git a/drivers/event/dpaa/dpaa_eventdev.c b/drivers/event/dpaa/dpaa_eventdev.c\nindex 1e247e4f4..d02b8694e 100644\n--- a/drivers/event/dpaa/dpaa_eventdev.c\n+++ b/drivers/event/dpaa/dpaa_eventdev.c\n@@ -27,12 +27,14 @@\n #include <rte_eventdev_pmd_vdev.h>\n #include <rte_ethdev.h>\n #include <rte_event_eth_rx_adapter.h>\n+#include <rte_cryptodev.h>\n #include <rte_dpaa_bus.h>\n #include <rte_dpaa_logs.h>\n #include <rte_cycles.h>\n #include <rte_kvargs.h>\n \n #include <dpaa_ethdev.h>\n+#include <dpaa_sec_event.h>\n #include \"dpaa_eventdev.h\"\n #include <dpaa_mempool.h>\n \n@@ -322,7 +324,7 @@ dpaa_event_dev_info_get(struct rte_eventdev *dev,\n \tEVENTDEV_INIT_FUNC_TRACE();\n \n \tRTE_SET_USED(dev);\n-\tdev_info->driver_name = \"event_dpaa\";\n+\tdev_info->driver_name = \"event_dpaa1\";\n \tdev_info->min_dequeue_timeout_ns =\n \t\tDPAA_EVENT_MIN_DEQUEUE_TIMEOUT;\n \tdev_info->max_dequeue_timeout_ns =\n@@ -718,6 +720,149 @@ dpaa_event_eth_rx_adapter_stop(const struct rte_eventdev *dev,\n \treturn 0;\n }\n \n+static int\n+dpaa_eventdev_crypto_caps_get(const struct rte_eventdev *dev,\n+\t\t\t const struct rte_cryptodev *cdev,\n+\t\t\t uint32_t *caps)\n+{\n+\tconst char *name = cdev->data->name;\n+\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tRTE_SET_USED(dev);\n+\n+\tif (!strncmp(name, \"dpaa_sec-\", 9))\n+\t\t*caps = RTE_EVENT_CRYPTO_ADAPTER_DPAA_CAP;\n+\telse\n+\t\treturn -1;\n+\n+\treturn 0;\n+}\n+\n+static int\n+dpaa_eventdev_crypto_queue_add_all(const struct rte_eventdev *dev,\n+\t\tconst struct rte_cryptodev *cryptodev,\n+\t\tconst struct rte_event *ev)\n+{\n+\tstruct dpaa_eventdev *priv = dev->data->dev_private;\n+\tuint8_t ev_qid = ev->queue_id;\n+\tu16 ch_id = priv->evq_info[ev_qid].ch_id;\n+\tint i, ret;\n+\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tfor (i = 0; i < cryptodev->data->nb_queue_pairs; i++) {\n+\t\tret = dpaa_sec_eventq_attach(cryptodev, i,\n+\t\t\t\tch_id, ev);\n+\t\tif (ret) {\n+\t\t\tDPAA_EVENTDEV_ERR(\"dpaa_sec_eventq_attach failed: ret %d\\n\",\n+\t\t\t\t ret);\n+\t\t\tgoto fail;\n+\t\t}\n+\t}\n+\treturn 0;\n+fail:\n+\tfor (i = (i - 1); i >= 0 ; i--)\n+\t\tdpaa_sec_eventq_detach(cryptodev, i);\n+\n+\treturn ret;\n+}\n+\n+static int\n+dpaa_eventdev_crypto_queue_add(const struct rte_eventdev *dev,\n+\t\tconst struct rte_cryptodev *cryptodev,\n+\t\tint32_t rx_queue_id,\n+\t\tconst struct rte_event *ev)\n+{\n+\tstruct dpaa_eventdev *priv = dev->data->dev_private;\n+\tuint8_t ev_qid = ev->queue_id;\n+\tu16 ch_id = priv->evq_info[ev_qid].ch_id;\n+\tint ret;\n+\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tif (rx_queue_id == -1)\n+\t\treturn dpaa_eventdev_crypto_queue_add_all(dev,\n+\t\t\t\tcryptodev, ev);\n+\n+\tret = dpaa_sec_eventq_attach(cryptodev, rx_queue_id,\n+\t\t\tch_id, ev);\n+\tif (ret) {\n+\t\tDPAA_EVENTDEV_ERR(\n+\t\t\t\"dpaa_sec_eventq_attach failed: ret: %d\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\treturn 0;\n+}\n+\n+static int\n+dpaa_eventdev_crypto_queue_del_all(const struct rte_eventdev *dev,\n+\t\t\t const struct rte_cryptodev *cdev)\n+{\n+\tint i, ret;\n+\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tRTE_SET_USED(dev);\n+\n+\tfor (i = 0; i < cdev->data->nb_queue_pairs; i++) {\n+\t\tret = dpaa_sec_eventq_detach(cdev, i);\n+\t\tif (ret) {\n+\t\t\tDPAA_EVENTDEV_ERR(\n+\t\t\t\t\"dpaa_sec_eventq_detach failed:ret %d\\n\", ret);\n+\t\t\treturn ret;\n+\t\t}\n+\t}\n+\n+\treturn 0;\n+}\n+\n+static int\n+dpaa_eventdev_crypto_queue_del(const struct rte_eventdev *dev,\n+\t\t\t const struct rte_cryptodev *cryptodev,\n+\t\t\t int32_t rx_queue_id)\n+{\n+\tint ret;\n+\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tif (rx_queue_id == -1)\n+\t\treturn dpaa_eventdev_crypto_queue_del_all(dev, cryptodev);\n+\n+\tret = dpaa_sec_eventq_detach(cryptodev, rx_queue_id);\n+\tif (ret) {\n+\t\tDPAA_EVENTDEV_ERR(\n+\t\t\t\"dpaa_sec_eventq_detach failed: ret: %d\\n\", ret);\n+\t\treturn ret;\n+\t}\n+\n+\treturn 0;\n+}\n+\n+static int\n+dpaa_eventdev_crypto_start(const struct rte_eventdev *dev,\n+\t\t\t const struct rte_cryptodev *cryptodev)\n+{\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tRTE_SET_USED(dev);\n+\tRTE_SET_USED(cryptodev);\n+\n+\treturn 0;\n+}\n+\n+static int\n+dpaa_eventdev_crypto_stop(const struct rte_eventdev *dev,\n+\t\t\t const struct rte_cryptodev *cryptodev)\n+{\n+\tEVENTDEV_INIT_FUNC_TRACE();\n+\n+\tRTE_SET_USED(dev);\n+\tRTE_SET_USED(cryptodev);\n+\n+\treturn 0;\n+}\n+\n static struct rte_eventdev_ops dpaa_eventdev_ops = {\n \t.dev_infos_get = dpaa_event_dev_info_get,\n \t.dev_configure = dpaa_event_dev_configure,\n@@ -738,6 +883,11 @@ static struct rte_eventdev_ops dpaa_eventdev_ops = {\n \t.eth_rx_adapter_queue_del = dpaa_event_eth_rx_adapter_queue_del,\n \t.eth_rx_adapter_start = dpaa_event_eth_rx_adapter_start,\n \t.eth_rx_adapter_stop = dpaa_event_eth_rx_adapter_stop,\n+\t.crypto_adapter_caps_get\t= dpaa_eventdev_crypto_caps_get,\n+\t.crypto_adapter_queue_pair_add\t= dpaa_eventdev_crypto_queue_add,\n+\t.crypto_adapter_queue_pair_del\t= dpaa_eventdev_crypto_queue_del,\n+\t.crypto_adapter_start\t\t= dpaa_eventdev_crypto_start,\n+\t.crypto_adapter_stop\t\t= dpaa_eventdev_crypto_stop,\n };\n \n static int flag_check_handler(__rte_unused const char *key,\n@@ -806,6 +956,8 @@ dpaa_event_dev_create(const char *name, const char *params)\n \t\teventdev->dequeue_burst = dpaa_event_dequeue_burst_intr;\n \t}\n \n+\tRTE_LOG(INFO, PMD, \"%s eventdev added\", name);\n+\n \t/* For secondary processes, the primary has done all the work */\n \tif (rte_eal_process_type() != RTE_PROC_PRIMARY)\n \t\treturn 0;\ndiff --git a/drivers/event/dpaa/dpaa_eventdev.h b/drivers/event/dpaa/dpaa_eventdev.h\nindex 8134e6ba9..b8f247c61 100644\n--- a/drivers/event/dpaa/dpaa_eventdev.h\n+++ b/drivers/event/dpaa/dpaa_eventdev.h\n@@ -40,6 +40,11 @@ do {\t\t\t\t\t\t\\\n \t\tRTE_EVENT_ETH_RX_ADAPTER_CAP_MULTI_EVENTQ | \\\n \t\tRTE_EVENT_ETH_RX_ADAPTER_CAP_OVERRIDE_FLOW_ID)\n \n+#define RTE_EVENT_CRYPTO_ADAPTER_DPAA_CAP \\\n+\t\t(RTE_EVENT_CRYPTO_ADAPTER_CAP_INTERNAL_PORT_OP_NEW | \\\n+\t\tRTE_EVENT_CRYPTO_ADAPTER_CAP_INTERNAL_PORT_QP_EV_BIND | \\\n+\t\tRTE_EVENT_CRYPTO_ADAPTER_CAP_SESSION_PRIVATE_DATA)\n+\n struct dpaa_eventq {\n \t/* Channel Id */\n \tuint16_t ch_id;\n", "prefixes": [ "2/2" ] }{ "id": 58878, "url": "