get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 52444,
    "url": "https://patches.dpdk.org/api/patches/52444/?format=api",
    "web_url": "https://patches.dpdk.org/project/dpdk/patch/20190408182510.16078-5-stephen@networkplumber.org/",
    "project": {
        "id": 1,
        "url": "https://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": "<20190408182510.16078-5-stephen@networkplumber.org>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20190408182510.16078-5-stephen@networkplumber.org",
    "date": "2019-04-08T18:25:09",
    "name": "[v1,4/5] app/test: use lcore accessor functions",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "d471439bf967040c657bb58ab6dff0522afe7bc3",
    "submitter": {
        "id": 27,
        "url": "https://patches.dpdk.org/api/people/27/?format=api",
        "name": "Stephen Hemminger",
        "email": "stephen@networkplumber.org"
    },
    "delegate": {
        "id": 1,
        "url": "https://patches.dpdk.org/api/users/1/?format=api",
        "username": "tmonjalo",
        "first_name": "Thomas",
        "last_name": "Monjalon",
        "email": "thomas@monjalon.net"
    },
    "mbox": "https://patches.dpdk.org/project/dpdk/patch/20190408182510.16078-5-stephen@networkplumber.org/mbox/",
    "series": [
        {
            "id": 4190,
            "url": "https://patches.dpdk.org/api/series/4190/?format=api",
            "web_url": "https://patches.dpdk.org/project/dpdk/list/?series=4190",
            "date": "2019-04-08T18:25:05",
            "name": "make lcore_config internal",
            "version": 1,
            "mbox": "https://patches.dpdk.org/series/4190/mbox/"
        }
    ],
    "comments": "https://patches.dpdk.org/api/patches/52444/comments/",
    "check": "success",
    "checks": "https://patches.dpdk.org/api/patches/52444/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 7183B58FE;\n\tMon,  8 Apr 2019 20:25:29 +0200 (CEST)",
            "from mail-pf1-f196.google.com (mail-pf1-f196.google.com\n\t[209.85.210.196]) by dpdk.org (Postfix) with ESMTP id 8D8845681\n\tfor <dev@dpdk.org>; Mon,  8 Apr 2019 20:25:20 +0200 (CEST)",
            "by mail-pf1-f196.google.com with SMTP id 9so8086937pfj.13\n\tfor <dev@dpdk.org>; Mon, 08 Apr 2019 11:25:20 -0700 (PDT)",
            "from shemminger-XPS-13-9360.lan (204-195-22-127.wavecable.com.\n\t[204.195.22.127]) by smtp.gmail.com with ESMTPSA id\n\td25sm40891081pfn.154.2019.04.08.11.25.17\n\t(version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128);\n\tMon, 08 Apr 2019 11:25:18 -0700 (PDT)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=networkplumber-org.20150623.gappssmtp.com; s=20150623;\n\th=from:to:cc:subject:date:message-id:in-reply-to:references;\n\tbh=sQ+iNUXhTxBVtOq8XRGTYh30Wpb2MtAgGcRRbB25FMs=;\n\tb=eZymP0E08kslFOo6qPH/ErkDHVw8PsGS2UMVJR98DbjllXF3epCQoE/MEt4YBokFXD\n\tv7EFIAMnjAm1HRSPUKIyb+onnSzyXjRRPdVMjt5nLZLT+021T/9eyAp6iM0cScRypW50\n\tNkrIcMaVmPGFGuEqzJ2VwvestwcclKzLkE5qbIblNKNgBfoQ742GWIX98Ds8zE7M7VD9\n\tNE0c0fFaRhtwVv0K6ApQAEDJQMeYOMg2HezjFOASuizuL9qXX8ooW8k3UyH5VfZBR+VC\n\tO3OtAmiSab+WdR4gDNA+lhvCeViY8dRJiID4DBxyB/uQ4PRcqRCodBQaanUgtMEWoiGl\n\tyyyg==",
        "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=sQ+iNUXhTxBVtOq8XRGTYh30Wpb2MtAgGcRRbB25FMs=;\n\tb=G2bu5W93BXNv/opFcdV2+yKQJ2jWgpMe/b7Sm2m3kGZ8yIPzb3dUUV/e+K94uwHGJx\n\tipI6i2VQuXKD+klBIj9fQcUQSRiNpnRJ4j7YRUz4mIUJ55dIyM1uQfauZokgbDzH8xnA\n\tUL8L+UdoLEhS4fJUIJwQ+RVmCc4y+O3c+Oy1atY1nNlcpfptkPuozyJ16MtmGMKz30st\n\t+q6uHhkQrDmDbx7gVYwOtvRSHDYwacBqt274g7rhfpxpDjKRv3VAzCUP18Ztx0PVJeko\n\t7crcQz45k+SHaT28pvHZbH2FB+NW6bAWy87hx5A2wn/XMrcSIxS/JLiSsbpoXSHvpoX9\n\twjCQ==",
        "X-Gm-Message-State": "APjAAAV9qEKLcOQAg1QuLGSmlClOhqa/l+fUwphMfvkWXAwXmF0sM7Te\n\t8ztUF1E/BjD8WL4bVa+0Tj6FG52StEBEKQ==",
        "X-Google-Smtp-Source": "APXvYqzO1reOP735IA0a8rrJJjQOjUKTlG/EOASgLEqqtaMc/UYEX4Hga7hRPwCeQhhUF2S9fqoHYA==",
        "X-Received": "by 2002:a65:420b:: with SMTP id\n\tc11mr30038260pgq.24.1554747919113; \n\tMon, 08 Apr 2019 11:25:19 -0700 (PDT)",
        "From": "Stephen Hemminger <stephen@networkplumber.org>",
        "To": "dev@dpdk.org",
        "Cc": "Stephen Hemminger <stephen@networkplumber.org>",
        "Date": "Mon,  8 Apr 2019 11:25:09 -0700",
        "Message-Id": "<20190408182510.16078-5-stephen@networkplumber.org>",
        "X-Mailer": "git-send-email 2.17.1",
        "In-Reply-To": "<20190408182510.16078-1-stephen@networkplumber.org>",
        "References": "<20190408182510.16078-1-stephen@networkplumber.org>",
        "Subject": "[dpdk-dev] [PATCH v1 4/5] app/test: use lcore accessor functions",
        "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": "Use the new accessor functions.  Don't refer to lcore_config directly.\n\nSigned-off-by: Stephen Hemminger <stephen@networkplumber.org>\n---\n app/test/test_cryptodev.c         |  2 +-\n app/test/test_hash_readwrite_lf.c | 14 +++++++-------\n app/test/test_ring_perf.c         | 22 ++++++++++++----------\n app/test/test_stack_perf.c        | 20 ++++++++++----------\n 4 files changed, 30 insertions(+), 28 deletions(-)",
    "diff": "diff --git a/app/test/test_cryptodev.c b/app/test/test_cryptodev.c\nindex 9f31aaa7e6b2..eca6d3db16a5 100644\n--- a/app/test/test_cryptodev.c\n+++ b/app/test/test_cryptodev.c\n@@ -378,7 +378,7 @@ testsuite_setup(void)\n \t\t\tstrcpy(temp_str, vdev_args);\n \t\t\tstrlcat(temp_str, \";\", sizeof(temp_str));\n \t\t\tslave_core_count++;\n-\t\t\tsocket_id = lcore_config[i].socket_id;\n+\t\t\tsocket_id = rte_lcore_to_socket_id(i);\n \t\t}\n \t\tif (slave_core_count != 2) {\n \t\t\tRTE_LOG(ERR, USER1,\ndiff --git a/app/test/test_hash_readwrite_lf.c b/app/test/test_hash_readwrite_lf.c\nindex 4ab4c8ee64cf..1361a8aa4c9c 100644\n--- a/app/test/test_hash_readwrite_lf.c\n+++ b/app/test/test_hash_readwrite_lf.c\n@@ -741,7 +741,7 @@ test_hash_add_no_ks_lookup_hit(struct rwc_perf *rwc_perf_results, int rwc_lf,\n \t\t\trte_eal_mp_wait_lcore();\n \n \t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\tgoto err;\n \n \t\t\tunsigned long long cycles_per_lookup =\n@@ -813,7 +813,7 @@ test_hash_add_no_ks_lookup_miss(struct rwc_perf *rwc_perf_results, int rwc_lf,\n \t\t\tif (ret < 0)\n \t\t\t\tgoto err;\n \t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\tgoto err;\n \n \t\t\tunsigned long long cycles_per_lookup =\n@@ -889,7 +889,7 @@ test_hash_add_ks_lookup_hit_non_sp(struct rwc_perf *rwc_perf_results,\n \t\t\tif (ret < 0)\n \t\t\t\tgoto err;\n \t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\tgoto err;\n \n \t\t\tunsigned long long cycles_per_lookup =\n@@ -965,7 +965,7 @@ test_hash_add_ks_lookup_hit_sp(struct rwc_perf *rwc_perf_results, int rwc_lf,\n \t\t\tif (ret < 0)\n \t\t\t\tgoto err;\n \t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\tgoto err;\n \n \t\t\tunsigned long long cycles_per_lookup =\n@@ -1040,7 +1040,7 @@ test_hash_add_ks_lookup_miss(struct rwc_perf *rwc_perf_results, int rwc_lf, int\n \t\t\tif (ret < 0)\n \t\t\t\tgoto err;\n \t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\tgoto err;\n \n \t\t\tunsigned long long cycles_per_lookup =\n@@ -1141,7 +1141,7 @@ test_hash_multi_add_lookup(struct rwc_perf *rwc_perf_results, int rwc_lf,\n \t\t\t\trte_eal_mp_wait_lcore();\n \n \t\t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\t\tgoto err;\n \n \t\t\t\tunsigned long long cycles_per_lookup =\n@@ -1225,7 +1225,7 @@ test_hash_add_ks_lookup_hit_extbkt(struct rwc_perf *rwc_perf_results,\n \t\t\trte_eal_mp_wait_lcore();\n \n \t\t\tfor (i = 1; i <= rwc_core_cnt[n]; i++)\n-\t\t\t\tif (lcore_config[i].ret < 0)\n+\t\t\t\tif (rte_lcore_return_code(i) < 0)\n \t\t\t\t\tgoto err;\n \n \t\t\tunsigned long long cycles_per_lookup =\ndiff --git a/app/test/test_ring_perf.c b/app/test/test_ring_perf.c\nindex ebb3939f51d0..6eccccfe93b4 100644\n--- a/app/test/test_ring_perf.c\n+++ b/app/test/test_ring_perf.c\n@@ -52,10 +52,11 @@ get_two_hyperthreads(struct lcore_pair *lcp)\n \t\tRTE_LCORE_FOREACH(id2) {\n \t\t\tif (id1 == id2)\n \t\t\t\tcontinue;\n-\t\t\tc1 = lcore_config[id1].core_id;\n-\t\t\tc2 = lcore_config[id2].core_id;\n-\t\t\ts1 = lcore_config[id1].socket_id;\n-\t\t\ts2 = lcore_config[id2].socket_id;\n+\n+\t\t\tc1 = rte_lcore_to_cpu_id(id1);\n+\t\t\tc2 = rte_lcore_to_cpu_id(id2);\n+\t\t\ts1 = rte_lcore_to_socket_id(id1);\n+\t\t\ts2 = rte_lcore_to_socket_id(id2);\n \t\t\tif ((c1 == c2) && (s1 == s2)){\n \t\t\t\tlcp->c1 = id1;\n \t\t\t\tlcp->c2 = id2;\n@@ -75,10 +76,11 @@ get_two_cores(struct lcore_pair *lcp)\n \t\tRTE_LCORE_FOREACH(id2) {\n \t\t\tif (id1 == id2)\n \t\t\t\tcontinue;\n-\t\t\tc1 = lcore_config[id1].core_id;\n-\t\t\tc2 = lcore_config[id2].core_id;\n-\t\t\ts1 = lcore_config[id1].socket_id;\n-\t\t\ts2 = lcore_config[id2].socket_id;\n+\n+\t\t\tc1 = rte_lcore_to_cpu_id(id1);\n+\t\t\tc2 = rte_lcore_to_cpu_id(id2);\n+\t\t\ts1 = rte_lcore_to_socket_id(id1);\n+\t\t\ts2 = rte_lcore_to_socket_id(id2);\n \t\t\tif ((c1 != c2) && (s1 == s2)){\n \t\t\t\tlcp->c1 = id1;\n \t\t\t\tlcp->c2 = id2;\n@@ -98,8 +100,8 @@ get_two_sockets(struct lcore_pair *lcp)\n \t\tRTE_LCORE_FOREACH(id2) {\n \t\t\tif (id1 == id2)\n \t\t\t\tcontinue;\n-\t\t\ts1 = lcore_config[id1].socket_id;\n-\t\t\ts2 = lcore_config[id2].socket_id;\n+\t\t\ts1 = rte_lcore_to_socket_id(id1);\n+\t\t\ts2 = rte_lcore_to_socket_id(id2);\n \t\t\tif (s1 != s2){\n \t\t\t\tlcp->c1 = id1;\n \t\t\t\tlcp->c2 = id2;\ndiff --git a/app/test/test_stack_perf.c b/app/test/test_stack_perf.c\nindex ba27fbf7076d..70561fecda0d 100644\n--- a/app/test/test_stack_perf.c\n+++ b/app/test/test_stack_perf.c\n@@ -44,10 +44,10 @@ get_two_hyperthreads(struct lcore_pair *lcp)\n \t\tRTE_LCORE_FOREACH(id[1]) {\n \t\t\tif (id[0] == id[1])\n \t\t\t\tcontinue;\n-\t\t\tcore[0] = lcore_config[id[0]].core_id;\n-\t\t\tcore[1] = lcore_config[id[1]].core_id;\n-\t\t\tsocket[0] = lcore_config[id[0]].socket_id;\n-\t\t\tsocket[1] = lcore_config[id[1]].socket_id;\n+\t\t\tcore[0] = rte_lcore_to_cpu_id(id[0]);\n+\t\t\tcore[1] = rte_lcore_to_cpu_id(id[1]);\n+\t\t\tsocket[0] = rte_lcore_to_socket_id(id[0]);\n+\t\t\tsocket[1] = rte_lcore_to_socket_id(id[1]);\n \t\t\tif ((core[0] == core[1]) && (socket[0] == socket[1])) {\n \t\t\t\tlcp->c1 = id[0];\n \t\t\t\tlcp->c2 = id[1];\n@@ -70,10 +70,10 @@ get_two_cores(struct lcore_pair *lcp)\n \t\tRTE_LCORE_FOREACH(id[1]) {\n \t\t\tif (id[0] == id[1])\n \t\t\t\tcontinue;\n-\t\t\tcore[0] = lcore_config[id[0]].core_id;\n-\t\t\tcore[1] = lcore_config[id[1]].core_id;\n-\t\t\tsocket[0] = lcore_config[id[0]].socket_id;\n-\t\t\tsocket[1] = lcore_config[id[1]].socket_id;\n+\t\t\tcore[0] = rte_lcore_to_cpu_id(id[0]);\n+\t\t\tcore[1] = rte_lcore_to_cpu_id(id[1]);\n+\t\t\tsocket[0] = rte_lcore_to_socket_id(id[0]);\n+\t\t\tsocket[1] = rte_lcore_to_socket_id(id[1]);\n \t\t\tif ((core[0] != core[1]) && (socket[0] == socket[1])) {\n \t\t\t\tlcp->c1 = id[0];\n \t\t\t\tlcp->c2 = id[1];\n@@ -95,8 +95,8 @@ get_two_sockets(struct lcore_pair *lcp)\n \t\tRTE_LCORE_FOREACH(id[1]) {\n \t\t\tif (id[0] == id[1])\n \t\t\t\tcontinue;\n-\t\t\tsocket[0] = lcore_config[id[0]].socket_id;\n-\t\t\tsocket[1] = lcore_config[id[1]].socket_id;\n+\t\t\tsocket[0] = rte_lcore_to_socket_id(id[0]);\n+\t\t\tsocket[1] = rte_lcore_to_socket_id(id[1]);\n \t\t\tif (socket[0] != socket[1]) {\n \t\t\t\tlcp->c1 = id[0];\n \t\t\t\tlcp->c2 = id[1];\n",
    "prefixes": [
        "v1",
        "4/5"
    ]
}