Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/42347/?format=api
http://patches.dpdk.org/api/patches/42347/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/cf2ae4585d23c663d4c899111251636c376ba945.1530791217.git.gaetan.rivet@6wind.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": "<cf2ae4585d23c663d4c899111251636c376ba945.1530791217.git.gaetan.rivet@6wind.com>", "list_archive_url": "https://inbox.dpdk.org/dev/cf2ae4585d23c663d4c899111251636c376ba945.1530791217.git.gaetan.rivet@6wind.com", "date": "2018-07-05T11:48:19", "name": "[v10,12/27] eal/dev: implement device iteration initialization", "commit_ref": null, "pull_url": null, "state": "superseded", "archived": true, "hash": "6cac7b2e36c8b0e90d8382809fed5db0adacc11a", "submitter": { "id": 269, "url": "http://patches.dpdk.org/api/people/269/?format=api", "name": "Gaëtan Rivet", "email": "gaetan.rivet@6wind.com" }, "delegate": { "id": 1, "url": "http://patches.dpdk.org/api/users/1/?format=api", "username": "tmonjalo", "first_name": "Thomas", "last_name": "Monjalon", "email": "thomas@monjalon.net" }, "mbox": "http://patches.dpdk.org/project/dpdk/patch/cf2ae4585d23c663d4c899111251636c376ba945.1530791217.git.gaetan.rivet@6wind.com/mbox/", "series": [ { "id": 419, "url": "http://patches.dpdk.org/api/series/419/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=419", "date": "2018-07-05T11:48:07", "name": "Device querying", "version": 10, "mbox": "http://patches.dpdk.org/series/419/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/42347/comments/", "check": "success", "checks": "http://patches.dpdk.org/api/patches/42347/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 885611BF4B;\n\tThu, 5 Jul 2018 13:49:35 +0200 (CEST)", "from mail-wm0-f65.google.com (mail-wm0-f65.google.com\n\t[74.125.82.65]) by dpdk.org (Postfix) with ESMTP id E9C9F1BED9\n\tfor <dev@dpdk.org>; Thu, 5 Jul 2018 13:49:12 +0200 (CEST)", "by mail-wm0-f65.google.com with SMTP id n17-v6so10381943wmh.2\n\tfor <dev@dpdk.org>; Thu, 05 Jul 2018 04:49:12 -0700 (PDT)", "from bidouze.dev.6wind.com. (host.78.145.23.62.rev.coltfrance.com.\n\t[62.23.145.78]) by smtp.gmail.com with ESMTPSA id\n\to42-v6sm15809183wrc.50.2018.07.05.04.49.10\n\t(version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128);\n\tThu, 05 Jul 2018 04:49:11 -0700 (PDT)" ], "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=6wind-com.20150623.gappssmtp.com; s=20150623;\n\th=from:to:cc:subject:date:message-id:in-reply-to:references;\n\tbh=rgl50crsTMdz8uMA9l9eRovWUssSsKezern0x9vWcy0=;\n\tb=NZ4cPeTqOlJXodHD/PdiGgl4IuX4vLNOJJtXQ1TEfZmr6xSvawuzptY3WRzaeB7IPu\n\t7cnxfqLeLaNT3hfjdIyY+e/f8K2rCLeEH/b7CxmXSxjLMnZ8SsFJsC5MgM6/zE171rnY\n\tUWWK4mm90ubTAPQXrWKy181FCNn2GC5EuqyUshO6oCUu7SXNdkvTJoFEFQqyqov/qyuU\n\trHiZL+IFI198YqKU8gGKMrrvyEx0BtoREccuPCD2SU7upZizyhWWcBFRkNQHYKADEHne\n\tfRQNXsXr70hcnDCsc4qrMaobB41jcFPqwp1VlvL77KCiQkGchD95a3EkfvDIQdedlvCu\n\t9lcg==", "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=1e100.net; s=20161025;\n\th=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to\n\t:references;\n\tbh=rgl50crsTMdz8uMA9l9eRovWUssSsKezern0x9vWcy0=;\n\tb=EnknH8VVglcxdQWV5qauhIKRyMyGcyCGxv1DZB6WnAwS0wLWzzwQLbfYp1ko+iyei+\n\t3IN2d9JVkXpy3GzQFI8x6PILYC3aGnLd8kzIXwLso7prOZh6fscv4kM60nunU0fzQPF/\n\t8FMfWqdWtcZTbKbVeHSART9BQi8EJwQHDkQFc97fCvIJ+PYNhk91lfjaqgfL7A+IhYKe\n\tpKBBgVbdkwweJ0v0A1nn8EdHEGUAol1/B4BFsdDfjP70MllHuQfqZftIFKN7nzKyOTBW\n\tSnO7xqMDl8ho+KwXPPL2bGBowTPxP09iFMzJLd8ULxO4pH8UitHxpN2vPQvtYFnuH71y\n\tODXg==", "X-Gm-Message-State": "APt69E00m9y9sXZlPtgjrC1IrMx2BjbI8mLI96IFuazhT3aVwaWwlcHx\n\teNiKRfA3UhpJBq8ll7HFRbeTFMTT", "X-Google-Smtp-Source": "AAOMgpcOfMkAalTWy8dM0VwTmI3ClkiTB3t0SRLuoi980Fszz98gsNevsDPH4GxTYIh879EqG6wh/Q==", "X-Received": "by 2002:a1c:8893:: with SMTP id\n\tk141-v6mr4039172wmd.36.1530791352298; \n\tThu, 05 Jul 2018 04:49:12 -0700 (PDT)", "From": "Gaetan Rivet <gaetan.rivet@6wind.com>", "To": "dev@dpdk.org", "Cc": "Gaetan Rivet <gaetan.rivet@6wind.com>", "Date": "Thu, 5 Jul 2018 13:48:19 +0200", "Message-Id": "<cf2ae4585d23c663d4c899111251636c376ba945.1530791217.git.gaetan.rivet@6wind.com>", "X-Mailer": "git-send-email 2.18.0", "In-Reply-To": "<cover.1530791217.git.gaetan.rivet@6wind.com>", "References": "<cover.1530791217.git.gaetan.rivet@6wind.com>", "Subject": "[dpdk-dev] [PATCH v10 12/27] eal/dev: implement device iteration\n\tinitialization", "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": "Parse a device description.\nSplit this description in their relevant part for each layers.\nNo dynamic allocation is performed.\n\nSigned-off-by: Gaetan Rivet <gaetan.rivet@6wind.com>\n---\n lib/Makefile | 1 +\n lib/librte_eal/bsdapp/eal/Makefile | 1 +\n lib/librte_eal/common/eal_common_dev.c | 55 +++++++++++++++++++++++++\n lib/librte_eal/common/include/rte_dev.h | 24 +++++++++++\n lib/librte_eal/linuxapp/eal/Makefile | 1 +\n lib/librte_eal/rte_eal_version.map | 1 +\n 6 files changed, 83 insertions(+)", "diff": "diff --git a/lib/Makefile b/lib/Makefile\nindex 8a65525cd..afa604e20 100644\n--- a/lib/Makefile\n+++ b/lib/Makefile\n@@ -7,6 +7,7 @@ DIRS-y += librte_compat\n DIRS-$(CONFIG_RTE_LIBRTE_KVARGS) += librte_kvargs\n DEPDIRS-librte_kvargs := librte_compat\n DIRS-$(CONFIG_RTE_LIBRTE_EAL) += librte_eal\n+DEPDIRS-librte_eal := librte_kvargs\n DIRS-$(CONFIG_RTE_LIBRTE_PCI) += librte_pci\n DEPDIRS-librte_pci := librte_eal\n DIRS-$(CONFIG_RTE_LIBRTE_RING) += librte_ring\ndiff --git a/lib/librte_eal/bsdapp/eal/Makefile b/lib/librte_eal/bsdapp/eal/Makefile\nindex b0a1c880a..67b10ae0d 100644\n--- a/lib/librte_eal/bsdapp/eal/Makefile\n+++ b/lib/librte_eal/bsdapp/eal/Makefile\n@@ -18,6 +18,7 @@ CFLAGS += $(WERROR_FLAGS) -O3\n LDLIBS += -lexecinfo\n LDLIBS += -lpthread\n LDLIBS += -lgcc_s\n+LDLIBS += -lrte_kvargs\n \n EXPORT_MAP := ../../rte_eal_version.map\n \ndiff --git a/lib/librte_eal/common/eal_common_dev.c b/lib/librte_eal/common/eal_common_dev.c\nindex ce4b51469..5b7956d17 100644\n--- a/lib/librte_eal/common/eal_common_dev.c\n+++ b/lib/librte_eal/common/eal_common_dev.c\n@@ -10,9 +10,12 @@\n \n #include <rte_compat.h>\n #include <rte_bus.h>\n+#include <rte_class.h>\n #include <rte_dev.h>\n #include <rte_devargs.h>\n #include <rte_debug.h>\n+#include <rte_errno.h>\n+#include <rte_kvargs.h>\n #include <rte_log.h>\n #include <rte_spinlock.h>\n #include <rte_malloc.h>\n@@ -343,3 +346,55 @@ dev_callback_process(char *device_name, enum rte_dev_event_type event)\n \t}\n \trte_spinlock_unlock(&dev_event_lock);\n }\n+\n+__rte_experimental\n+int\n+rte_dev_iterator_init(struct rte_dev_iterator *it,\n+\t\t const char *devstr)\n+{\n+\tstruct rte_devargs da;\n+\tstruct rte_class *cls = NULL;\n+\tstruct rte_bus *bus = NULL;\n+\n+\t/* Having both busstr and clsstr NULL is illegal,\n+\t * marking this iterator as invalid unless\n+\t * everything goes well.\n+\t */\n+\tit->busstr = NULL;\n+\tit->clsstr = NULL;\n+\n+\tda.data = devstr;\n+\tif (rte_devargs_layers_parse(&da, devstr))\n+\t\tgoto get_out;\n+\n+\tbus = da.bus;\n+\tcls = da.cls;\n+\t/* The string should have at least\n+\t * one layer specified.\n+\t */\n+\tif (bus == NULL && cls == NULL) {\n+\t\tRTE_LOG(ERR, EAL,\n+\t\t\t\"Either bus or class must be specified.\\n\");\n+\t\trte_errno = EINVAL;\n+\t\tgoto get_out;\n+\t}\n+\tif (bus != NULL && bus->dev_iterate == NULL) {\n+\t\tRTE_LOG(ERR, EAL, \"Bus %s not supported\\n\", bus->name);\n+\t\trte_errno = ENOTSUP;\n+\t\tgoto get_out;\n+\t}\n+\tif (cls != NULL && cls->dev_iterate == NULL) {\n+\t\tRTE_LOG(ERR, EAL, \"Class %s not supported\\n\", cls->name);\n+\t\trte_errno = ENOTSUP;\n+\t\tgoto get_out;\n+\t}\n+\tit->busstr = da.busstr;\n+\tit->clsstr = da.clsstr;\n+\tit->devstr = devstr;\n+\tit->bus = bus;\n+\tit->cls = cls;\n+\tit->device = NULL;\n+\tit->class_device = NULL;\n+get_out:\n+\treturn -rte_errno;\n+}\ndiff --git a/lib/librte_eal/common/include/rte_dev.h b/lib/librte_eal/common/include/rte_dev.h\nindex 120df729f..7b7bd83bc 100644\n--- a/lib/librte_eal/common/include/rte_dev.h\n+++ b/lib/librte_eal/common/include/rte_dev.h\n@@ -332,6 +332,30 @@ typedef void *(*rte_dev_iterate_t)(const void *start,\n \t\t\t\t const char *devstr,\n \t\t\t\t const struct rte_dev_iterator *it);\n \n+/**\n+ * Initializes a device iterator.\n+ *\n+ * This iterator allows accessing a list of devices matching a criteria.\n+ * The device matching is made among all buses and classes currently registered,\n+ * filtered by the device description given as parameter.\n+ *\n+ * This function will not allocate any memory. It is safe to stop the\n+ * iteration at any moment and let the iterator go out of context.\n+ *\n+ * @param it\n+ * Device iterator handle.\n+ *\n+ * @param str\n+ * Device description string.\n+ *\n+ * @return\n+ * 0 on successful initialization.\n+ * <0 on error.\n+ */\n+__rte_experimental\n+int\n+rte_dev_iterator_init(struct rte_dev_iterator *it, const char *str);\n+\n #ifdef __cplusplus\n }\n #endif\ndiff --git a/lib/librte_eal/linuxapp/eal/Makefile b/lib/librte_eal/linuxapp/eal/Makefile\nindex babc8617a..885c48110 100644\n--- a/lib/librte_eal/linuxapp/eal/Makefile\n+++ b/lib/librte_eal/linuxapp/eal/Makefile\n@@ -27,6 +27,7 @@ LDLIBS += -lrt\n ifeq ($(CONFIG_RTE_EAL_NUMA_AWARE_HUGEPAGES),y)\n LDLIBS += -lnuma\n endif\n+LDLIBS += -lrte_kvargs\n \n # specific to linuxapp exec-env\n SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) := eal.c\ndiff --git a/lib/librte_eal/rte_eal_version.map b/lib/librte_eal/rte_eal_version.map\nindex 19d36b4c7..ac04120d6 100644\n--- a/lib/librte_eal/rte_eal_version.map\n+++ b/lib/librte_eal/rte_eal_version.map\n@@ -251,6 +251,7 @@ EXPERIMENTAL {\n \trte_dev_event_callback_unregister;\n \trte_dev_event_monitor_start;\n \trte_dev_event_monitor_stop;\n+\trte_dev_iterator_init;\n \trte_devargs_add;\n \trte_devargs_dump;\n \trte_devargs_insert;\n", "prefixes": [ "v10", "12/27" ] }{ "id": 42347, "url": "