get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 127912,
    "url": "http://patches.dpdk.org/api/patches/127912/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/20230601200812.672233-5-maxime.coquelin@redhat.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": "<20230601200812.672233-5-maxime.coquelin@redhat.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/20230601200812.672233-5-maxime.coquelin@redhat.com",
    "date": "2023-06-01T20:07:50",
    "name": "[v4,04/26] vhost: don't dump unneeded pages with IOTLB",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "6bf9881b3761fbe07e601e2635ef66e98322bc72",
    "submitter": {
        "id": 512,
        "url": "http://patches.dpdk.org/api/people/512/?format=api",
        "name": "Maxime Coquelin",
        "email": "maxime.coquelin@redhat.com"
    },
    "delegate": {
        "id": 2642,
        "url": "http://patches.dpdk.org/api/users/2642/?format=api",
        "username": "mcoquelin",
        "first_name": "Maxime",
        "last_name": "Coquelin",
        "email": "maxime.coquelin@redhat.com"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/20230601200812.672233-5-maxime.coquelin@redhat.com/mbox/",
    "series": [
        {
            "id": 28308,
            "url": "http://patches.dpdk.org/api/series/28308/?format=api",
            "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=28308",
            "date": "2023-06-01T20:07:46",
            "name": "Add VDUSE support to Vhost library",
            "version": 4,
            "mbox": "http://patches.dpdk.org/series/28308/mbox/"
        }
    ],
    "comments": "http://patches.dpdk.org/api/patches/127912/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/127912/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 0501042C08;\n\tThu,  1 Jun 2023 22:08:49 +0200 (CEST)",
            "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 815EF42D74;\n\tThu,  1 Jun 2023 22:08:36 +0200 (CEST)",
            "from us-smtp-delivery-124.mimecast.com\n (us-smtp-delivery-124.mimecast.com [170.10.129.124])\n by mails.dpdk.org (Postfix) with ESMTP id 0FA0A42D6C\n for <dev@dpdk.org>; Thu,  1 Jun 2023 22:08:34 +0200 (CEST)",
            "from mimecast-mx02.redhat.com (mimecast-mx02.redhat.com\n [66.187.233.88]) by relay.mimecast.com with ESMTP with STARTTLS\n (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id\n us-mta-307-DvfBpUnlMeyGUepVdFtfbA-1; Thu, 01 Jun 2023 16:08:31 -0400",
            "from smtp.corp.redhat.com (int-mx04.intmail.prod.int.rdu2.redhat.com\n [10.11.54.4])\n (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits))\n (No client certificate requested)\n by mimecast-mx02.redhat.com (Postfix) with ESMTPS id F1AAF185A795;\n Thu,  1 Jun 2023 20:08:30 +0000 (UTC)",
            "from max-t490s.redhat.com (unknown [10.39.208.25])\n by smtp.corp.redhat.com (Postfix) with ESMTP id 2BC1C2029F6D;\n Thu,  1 Jun 2023 20:08:28 +0000 (UTC)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com;\n s=mimecast20190719; t=1685650114;\n h=from:from:reply-to:subject:subject:date:date:message-id:message-id:\n to:to:cc:cc:mime-version:mime-version:content-type:content-type:\n content-transfer-encoding:content-transfer-encoding:\n in-reply-to:in-reply-to:references:references;\n bh=3viU0ucDifS7vbgVuPxlajnSbkTJ5nflHILVn2DSYNM=;\n b=L5Y9q8NS9DyypauUPuMqyrykQcWpK5hRAjy8J4M/wCTYdijQlNWlG9duk2QF1yuTHmHqpS\n 2UXDk3bz/JhjEqtdMHEZN50ftqfBLqIUF38VKnU5sXaodNqWGP+AcBgCAaTJ9vETLJ1Z6V\n FSQ5o2D004tcLUGlFn/V86c5aXdtX64=",
        "X-MC-Unique": "DvfBpUnlMeyGUepVdFtfbA-1",
        "From": "Maxime Coquelin <maxime.coquelin@redhat.com>",
        "To": "dev@dpdk.org, chenbo.xia@intel.com, david.marchand@redhat.com,\n mkp@redhat.com, fbl@redhat.com, jasowang@redhat.com,\n cunming.liang@intel.com, xieyongji@bytedance.com, echaudro@redhat.com,\n eperezma@redhat.com, amorenoz@redhat.com, lulu@redhat.com",
        "Cc": "Maxime Coquelin <maxime.coquelin@redhat.com>,\n\tstable@dpdk.org",
        "Subject": "[PATCH v4 04/26] vhost: don't dump unneeded pages with IOTLB",
        "Date": "Thu,  1 Jun 2023 22:07:50 +0200",
        "Message-Id": "<20230601200812.672233-5-maxime.coquelin@redhat.com>",
        "In-Reply-To": "<20230601200812.672233-1-maxime.coquelin@redhat.com>",
        "References": "<20230601200812.672233-1-maxime.coquelin@redhat.com>",
        "MIME-Version": "1.0",
        "X-Scanned-By": "MIMEDefang 3.1 on 10.11.54.4",
        "X-Mimecast-Spam-Score": "0",
        "X-Mimecast-Originator": "redhat.com",
        "Content-Transfer-Encoding": "8bit",
        "Content-Type": "text/plain; charset=\"US-ASCII\"; x-default=true",
        "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": "On IOTLB entry removal, previous fixes took care of not\nmarking pages shared with other IOTLB entries as DONTDUMP.\n\nHowever, if an IOTLB entry is spanned on multiple pages,\nthe other pages were kept as DODUMP while they might not\nhave been shared with other entries, increasing needlessly\nthe coredump size.\n\nThis patch addresses this issue by excluding only the\nshared pages from madvise's DONTDUMP.\n\nFixes: dea092d0addb (\"vhost: fix madvise arguments alignment\")\nCc: stable@dpdk.org\n\nSigned-off-by: Maxime Coquelin <maxime.coquelin@redhat.com>\nAcked-by: Mike Pattrick <mkp@redhat.com>\nReviewed-by: Chenbo Xia <chenbo.xia@intel.com>\n---\n lib/vhost/iotlb.c | 21 ++++++++++++++-------\n 1 file changed, 14 insertions(+), 7 deletions(-)",
    "diff": "diff --git a/lib/vhost/iotlb.c b/lib/vhost/iotlb.c\nindex 4ef038adff..95d67ac832 100644\n--- a/lib/vhost/iotlb.c\n+++ b/lib/vhost/iotlb.c\n@@ -54,16 +54,23 @@ static void\n vhost_user_iotlb_clear_dump(struct virtio_net *dev, struct vhost_iotlb_entry *node,\n \t\tstruct vhost_iotlb_entry *prev, struct vhost_iotlb_entry *next)\n {\n-\tuint64_t align;\n+\tuint64_t align, start, end;\n+\n+\tstart = node->uaddr;\n+\tend = node->uaddr + node->size;\n \n \talign = hua_to_alignment(dev->mem, (void *)(uintptr_t)node->uaddr);\n \n-\t/* Don't disable coredump if the previous node is in the same page */\n-\tif (!vhost_user_iotlb_share_page(prev, node, align)) {\n-\t\t/* Don't disable coredump if the next node is in the same page */\n-\t\tif (!vhost_user_iotlb_share_page(node, next, align))\n-\t\t\tmem_set_dump((void *)(uintptr_t)node->uaddr, node->size, false, align);\n-\t}\n+\t/* Skip first page if shared with previous entry. */\n+\tif (vhost_user_iotlb_share_page(prev, node, align))\n+\t\tstart = RTE_ALIGN_CEIL(start, align);\n+\n+\t/* Skip last page if shared with next entry. */\n+\tif (vhost_user_iotlb_share_page(node, next, align))\n+\t\tend = RTE_ALIGN_FLOOR(end, align);\n+\n+\tif (end > start)\n+\t\tmem_set_dump((void *)(uintptr_t)start, end - start, false, align);\n }\n \n static struct vhost_iotlb_entry *\n",
    "prefixes": [
        "v4",
        "04/26"
    ]
}