get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 125604,
    "url": "http://patches.dpdk.org/api/patches/125604/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20230329234049.11071-13-stephen@networkplumber.org/",
    "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": "<20230329234049.11071-13-stephen@networkplumber.org>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20230329234049.11071-13-stephen@networkplumber.org",
    "date": "2023-03-29T23:40:39",
    "name": "[v12,12/22] lpm: convert RTE_LOGTYPE_LPM to dynamic types",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "bde2477891144d7f3401f0392c3204ae3da5926d",
    "submitter": {
        "id": 27,
        "url": "http://patches.dpdk.org/api/people/27/?format=api",
        "name": "Stephen Hemminger",
        "email": "stephen@networkplumber.org"
    },
    "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/20230329234049.11071-13-stephen@networkplumber.org/mbox/",
    "series": [
        {
            "id": 27577,
            "url": "http://patches.dpdk.org/api/series/27577/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=27577",
            "date": "2023-03-29T23:40:27",
            "name": "Covert static log types in libraries to dynamic",
            "version": 12,
            "mbox": "http://patches.dpdk.org/series/27577/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/125604/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/125604/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@inbox.dpdk.org",
        "Delivered-To": "patchwork@inbox.dpdk.org",
        "Received": [
            "from mails.dpdk.org (mails.dpdk.org [217.70.189.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id A5F8F42868;\n\tThu, 30 Mar 2023 01:42:08 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id DB9D642D62;\n\tThu, 30 Mar 2023 01:41:14 +0200 (CEST)",
            "from mail-pl1-f175.google.com (mail-pl1-f175.google.com\n [209.85.214.175])\n by mails.dpdk.org (Postfix) with ESMTP id DB18742D17\n for <dev@dpdk.org>; Thu, 30 Mar 2023 01:41:10 +0200 (CEST)",
            "by mail-pl1-f175.google.com with SMTP id n14so626044plc.8\n for <dev@dpdk.org>; Wed, 29 Mar 2023 16:41:10 -0700 (PDT)",
            "from hermes.local (204-195-120-218.wavecable.com. [204.195.120.218])\n by smtp.gmail.com with ESMTPSA id\n f10-20020a17090274ca00b0019c2b1c4db1sm23360095plt.239.2023.03.29.16.41.09\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Wed, 29 Mar 2023 16:41:09 -0700 (PDT)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=networkplumber-org.20210112.gappssmtp.com; s=20210112; t=1680133270;\n h=content-transfer-encoding:mime-version:references:in-reply-to\n :message-id:date:subject:cc:to:from:from:to:cc:subject:date\n :message-id:reply-to;\n bh=5UmCQD0yXvyxxwVVk2Jvhz4Nnw3R8287jjpuzWnUKFY=;\n b=ujGBgBkWLYr/jJGJhhRTj/6d4tlxpHnD1pLQwqk6K+gFKNlNd1/Na/yi+uk9NZEnfJ\n 3UAutdSdxEcno/AmnkYcEPcsiQYpptBbdQPPxi+scAJLCmnrq7fadVxO2o+4X37cimwp\n 2twUqJGDG/QLdJof73czoJpOQUD/0vK5jPsdinEFapRDOKLHD4Z/24kT1EQWgGhQRmUH\n OafnHIv3QxWHhIxNyfiLrhTE2KOPgZFH9sSMnBKfrK1sMfsbchtRSEkrXTzszAlSgXG/\n rsTGReh6AjmVRq5OmGDgzu6HnM42GKr+tM1etAQFrTzg144lqjvFJn+20FeWAqJKum8g\n 5qOg==",
        "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20210112; t=1680133270;\n h=content-transfer-encoding:mime-version:references:in-reply-to\n :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc\n :subject:date:message-id:reply-to;\n bh=5UmCQD0yXvyxxwVVk2Jvhz4Nnw3R8287jjpuzWnUKFY=;\n b=3epnRt3WpoAZrT4XW33/bRmRh+2HmwLLTenCPDopp4WI47G0pzXdXL1bT5o6JlSGU8\n ZvklsSWSrIGCC3W94RAJaE1AKEQx5jzmTt3MQQ4KCDd3/eTMMAh3VpSVP1A1P3j2/iZh\n 4AQG7ytFVluqLWn/pN6v0WUnQPSEuhkKB1CozBJ+HqvD4uul6451unX0V81oxGuDifs2\n jV0m10l5B5dnucULydXfI/WkBMAXtzIHgUGXPU7CFxYGgvUiOk5Umgu0F1MrmgbUVetp\n tVBjfSuin+EyEAbfl17KbwEgexmAHnDax1ZUKAuTGFxrvqdgYthmzcNHkD+EeVqjoXyy\n 3HaQ==",
        "X-Gm-Message-State": "AAQBX9dABorscnMsnhLBhGpThnYeevHbJsbwzAw7rfTMQneXDWZsMDwg\n x7ORGU6Zq1kA6+JxG2a9LPgu/dVC4u3AcR7oXLilMg==",
        "X-Google-Smtp-Source": "\n AKy350bOTzebRir6YkapEiw0l7mBESe/7ijuKCbE4pt/qJ0aStbbeJSAvnEvS+yexeQICyDKX8YoPA==",
        "X-Received": "by 2002:a17:903:2291:b0:1a1:ee8c:eef5 with SMTP id\n b17-20020a170903229100b001a1ee8ceef5mr25244591plh.7.1680133270054;\n Wed, 29 Mar 2023 16:41:10 -0700 (PDT)",
        "From": "Stephen Hemminger <stephen@networkplumber.org>",
        "To": "dev@dpdk.org",
        "Cc": "Stephen Hemminger <stephen@networkplumber.org>,\n Vladimir Medvedkin <vladimir.medvedkin@intel.com>,\n Bruce Richardson <bruce.richardson@intel.com>",
        "Subject": "[PATCH v12 12/22] lpm: convert RTE_LOGTYPE_LPM to dynamic types",
        "Date": "Wed, 29 Mar 2023 16:40:39 -0700",
        "Message-Id": "<20230329234049.11071-13-stephen@networkplumber.org>",
        "X-Mailer": "git-send-email 2.39.2",
        "In-Reply-To": "<20230329234049.11071-1-stephen@networkplumber.org>",
        "References": "<20230329234049.11071-1-stephen@networkplumber.org>",
        "MIME-Version": "1.0",
        "Content-Transfer-Encoding": "8bit",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.29",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <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 <mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org"
    },
    "content": "Split lpm and lpm6 into separate log types since they\nare in different files and user may want to change log\nlevels for IPv4 vs IPv6.\n\nFor rib and fib libraries give them own types as well.\n\nSigned-off-by: Stephen Hemminger <stephen@networkplumber.org>\n---\n lib/eal/common/eal_common_log.c | 1 -\n lib/eal/include/rte_log.h       | 2 +-\n lib/fib/fib_log.h               | 4 ++++\n lib/fib/rte_fib.c               | 3 +++\n lib/fib/rte_fib6.c              | 2 ++\n lib/lpm/lpm_log.h               | 4 ++++\n lib/lpm/rte_lpm.c               | 3 +++\n lib/lpm/rte_lpm6.c              | 1 +\n lib/rib/rib_log.h               | 4 ++++\n lib/rib/rte_rib.c               | 3 +++\n lib/rib/rte_rib6.c              | 3 +++\n 11 files changed, 28 insertions(+), 2 deletions(-)\n create mode 100644 lib/fib/fib_log.h\n create mode 100644 lib/lpm/lpm_log.h\n create mode 100644 lib/rib/rib_log.h",
    "diff": "diff --git a/lib/eal/common/eal_common_log.c b/lib/eal/common/eal_common_log.c\nindex 4025d2039d55..6e2007e6ed4f 100644\n--- a/lib/eal/common/eal_common_log.c\n+++ b/lib/eal/common/eal_common_log.c\n@@ -351,7 +351,6 @@ static const struct logtype logtype_strings[] = {\n \t{RTE_LOGTYPE_EAL,        \"lib.eal\"},\n \t{RTE_LOGTYPE_PMD,        \"pmd\"},\n \t{RTE_LOGTYPE_HASH,       \"lib.hash\"},\n-\t{RTE_LOGTYPE_LPM,        \"lib.lpm\"},\n \t{RTE_LOGTYPE_KNI,        \"lib.kni\"},\n \t{RTE_LOGTYPE_METER,      \"lib.meter\"},\n \t{RTE_LOGTYPE_SCHED,      \"lib.sched\"},\ndiff --git a/lib/eal/include/rte_log.h b/lib/eal/include/rte_log.h\nindex 9f86bfdd0198..115a48bf05f5 100644\n--- a/lib/eal/include/rte_log.h\n+++ b/lib/eal/include/rte_log.h\n@@ -33,7 +33,7 @@ extern \"C\" {\n \t\t\t\t /* was RTE_LOGTYPE_TIMER */\n #define RTE_LOGTYPE_PMD        5 /**< Log related to poll mode driver. */\n #define RTE_LOGTYPE_HASH       6 /**< Log related to hash table. */\n-#define RTE_LOGTYPE_LPM        7 /**< Log related to LPM. */\n+\t\t\t\t /* was RTE_LOGTYPE_LPM */\n #define RTE_LOGTYPE_KNI        8 /**< Log related to KNI. */\n \t\t\t\t /* was RTE_LOGTYPE_ACL */\n \t\t\t\t /* was RTE_LOGTYPE_POWER */\ndiff --git a/lib/fib/fib_log.h b/lib/fib/fib_log.h\nnew file mode 100644\nindex 000000000000..c731c820f621\n--- /dev/null\n+++ b/lib/fib/fib_log.h\n@@ -0,0 +1,4 @@\n+/* SPDX-License-Identifier: BSD-3-Clause */\n+\n+extern int fib_logtype;\n+#define RTE_LOGTYPE_LPM fib_logtype\ndiff --git a/lib/fib/rte_fib.c b/lib/fib/rte_fib.c\nindex 0c3b20e00a5a..f88e71a59d5a 100644\n--- a/lib/fib/rte_fib.c\n+++ b/lib/fib/rte_fib.c\n@@ -17,6 +17,9 @@\n #include <rte_fib.h>\n \n #include \"dir24_8.h\"\n+#include \"fib_log.h\"\n+\n+RTE_LOG_REGISTER_DEFAULT(fib_logtype, INFO);\n \n TAILQ_HEAD(rte_fib_list, rte_tailq_entry);\n static struct rte_tailq_elem rte_fib_tailq = {\ndiff --git a/lib/fib/rte_fib6.c b/lib/fib/rte_fib6.c\nindex 28c69b38999f..ab1d9604796f 100644\n--- a/lib/fib/rte_fib6.c\n+++ b/lib/fib/rte_fib6.c\n@@ -10,6 +10,7 @@\n #include <rte_eal_memconfig.h>\n #include <rte_tailq.h>\n #include <rte_errno.h>\n+#include <rte_log.h>\n #include <rte_malloc.h>\n #include <rte_string_fns.h>\n \n@@ -17,6 +18,7 @@\n #include <rte_fib6.h>\n \n #include \"trie.h\"\n+#include \"fib_log.h\"\n \n TAILQ_HEAD(rte_fib6_list, rte_tailq_entry);\n static struct rte_tailq_elem rte_fib6_tailq = {\ndiff --git a/lib/lpm/lpm_log.h b/lib/lpm/lpm_log.h\nnew file mode 100644\nindex 000000000000..a0621b70a5fe\n--- /dev/null\n+++ b/lib/lpm/lpm_log.h\n@@ -0,0 +1,4 @@\n+/* SPDX-License-Identifier: BSD-3-Clause */\n+\n+extern int lpm_logtype;\n+#define RTE_LOGTYPE_LPM lpm_logtype\ndiff --git a/lib/lpm/rte_lpm.c b/lib/lpm/rte_lpm.c\nindex cdcd1b7f9e47..0ca82147866a 100644\n--- a/lib/lpm/rte_lpm.c\n+++ b/lib/lpm/rte_lpm.c\n@@ -18,6 +18,9 @@\n #include <rte_tailq.h>\n \n #include \"rte_lpm.h\"\n+#include \"lpm_log.h\"\n+\n+RTE_LOG_REGISTER_DEFAULT(lpm_logtype, INFO);\n \n TAILQ_HEAD(rte_lpm_list, rte_tailq_entry);\n \ndiff --git a/lib/lpm/rte_lpm6.c b/lib/lpm/rte_lpm6.c\nindex 8d21aeddb83c..873cc8bc267d 100644\n--- a/lib/lpm/rte_lpm6.c\n+++ b/lib/lpm/rte_lpm6.c\n@@ -20,6 +20,7 @@\n #include <rte_tailq.h>\n \n #include \"rte_lpm6.h\"\n+#include \"lpm_log.h\"\n \n #define RTE_LPM6_TBL24_NUM_ENTRIES        (1 << 24)\n #define RTE_LPM6_TBL8_GROUP_NUM_ENTRIES         256\ndiff --git a/lib/rib/rib_log.h b/lib/rib/rib_log.h\nnew file mode 100644\nindex 000000000000..f3ee513ca854\n--- /dev/null\n+++ b/lib/rib/rib_log.h\n@@ -0,0 +1,4 @@\n+/* SPDX-License-Identifier: BSD-3-Clause */\n+\n+extern int rib_logtype;\n+#define RTE_LOGTYPE_LPM rib_logtype\ndiff --git a/lib/rib/rte_rib.c b/lib/rib/rte_rib.c\nindex 812a2597d117..a62e951a8e0e 100644\n--- a/lib/rib/rte_rib.c\n+++ b/lib/rib/rte_rib.c\n@@ -16,6 +16,9 @@\n \n #include <rte_rib.h>\n \n+RTE_LOG_REGISTER_DEFAULT(rib_logtype, INFO);\n+#define RTE_LOGTYPE_LPM rib_logtype\n+\n TAILQ_HEAD(rte_rib_list, rte_tailq_entry);\n static struct rte_tailq_elem rte_rib_tailq = {\n \t.name = \"RTE_RIB\",\ndiff --git a/lib/rib/rte_rib6.c b/lib/rib/rte_rib6.c\nindex ae44281ae105..5765995197f8 100644\n--- a/lib/rib/rte_rib6.c\n+++ b/lib/rib/rte_rib6.c\n@@ -9,6 +9,7 @@\n \n #include <rte_eal_memconfig.h>\n #include <rte_errno.h>\n+#include <rte_log.h>\n #include <rte_malloc.h>\n #include <rte_mempool.h>\n #include <rte_string_fns.h>\n@@ -16,6 +17,8 @@\n \n #include <rte_rib6.h>\n \n+#include \"rib_log.h\"\n+\n #define RTE_RIB_VALID_NODE\t1\n #define RIB6_MAXDEPTH\t\t128\n /* Maximum length of a RIB6 name. */\n",
    "prefixes": [
        "v12",
        "12/22"
    ]
}