get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/58878/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 58878,
    "url": "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"
    ]
}