Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/2194168/?format=api
{ "id": 2194168, "url": "http://patchwork.ozlabs.org/api/patches/2194168/?format=api", "web_url": "http://patchwork.ozlabs.org/project/qemu-ppc/patch/20260206221908.1451528-3-pierrick.bouvier@linaro.org/", "project": { "id": 69, "url": "http://patchwork.ozlabs.org/api/projects/69/?format=api", "name": "QEMU powerpc development", "link_name": "qemu-ppc", "list_id": "qemu-ppc.nongnu.org", "list_email": "qemu-ppc@nongnu.org", "web_url": "", "scm_url": "", "webscm_url": "", "list_archive_url": "", "list_archive_url_format": "", "commit_url_format": "" }, "msgid": "<20260206221908.1451528-3-pierrick.bouvier@linaro.org>", "list_archive_url": null, "date": "2026-02-06T22:19:01", "name": "[v5,2/9] hw/virtio: Introduce VirtIODevice::access_is_big_endian boolean field", "commit_ref": null, "pull_url": null, "state": "new", "archived": false, "hash": "4eed7cde49b8ffdd77854062a707e65e9500aea2", "submitter": { "id": 85798, "url": "http://patchwork.ozlabs.org/api/people/85798/?format=api", "name": "Pierrick Bouvier", "email": "pierrick.bouvier@linaro.org" }, "delegate": null, "mbox": "http://patchwork.ozlabs.org/project/qemu-ppc/patch/20260206221908.1451528-3-pierrick.bouvier@linaro.org/mbox/", "series": [ { "id": 491347, "url": "http://patchwork.ozlabs.org/api/series/491347/?format=api", "web_url": "http://patchwork.ozlabs.org/project/qemu-ppc/list/?series=491347", "date": "2026-02-06T22:19:02", "name": "single-binary: hw/virtio", "version": 5, "mbox": "http://patchwork.ozlabs.org/series/491347/mbox/" } ], "comments": "http://patchwork.ozlabs.org/api/patches/2194168/comments/", "check": "pending", "checks": "http://patchwork.ozlabs.org/api/patches/2194168/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<qemu-ppc-bounces+incoming=patchwork.ozlabs.org@nongnu.org>", "X-Original-To": "incoming@patchwork.ozlabs.org", "Delivered-To": "patchwork-incoming@legolas.ozlabs.org", "Authentication-Results": [ "legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=linaro.org header.i=@linaro.org header.a=rsa-sha256\n header.s=google header.b=FWa93Z95;\n\tdkim-atps=neutral", "legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=nongnu.org\n (client-ip=209.51.188.17; helo=lists.gnu.org;\n envelope-from=qemu-ppc-bounces+incoming=patchwork.ozlabs.org@nongnu.org;\n receiver=patchwork.ozlabs.org)" ], "Received": [ "from lists.gnu.org (lists.gnu.org [209.51.188.17])\n\t(using TLSv1.2 with cipher ECDHE-ECDSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4f77pr3QrRz1xvD\n\tfor <incoming@patchwork.ozlabs.org>; Sat, 07 Feb 2026 09:21:24 +1100 (AEDT)", "from localhost ([::1] helo=lists1p.gnu.org)\n\tby lists.gnu.org with esmtp (Exim 4.90_1)\n\t(envelope-from <qemu-ppc-bounces@nongnu.org>)\n\tid 1voUAd-000648-Gg; Fri, 06 Feb 2026 17:19:23 -0500", "from eggs.gnu.org ([2001:470:142:3::10])\n by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <pierrick.bouvier@linaro.org>)\n id 1voUAb-00062A-9j\n for qemu-ppc@nongnu.org; Fri, 06 Feb 2026 17:19:21 -0500", "from mail-pl1-x636.google.com ([2607:f8b0:4864:20::636])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128)\n (Exim 4.90_1) (envelope-from <pierrick.bouvier@linaro.org>)\n id 1voUAZ-00079B-Hy\n for qemu-ppc@nongnu.org; Fri, 06 Feb 2026 17:19:20 -0500", "by mail-pl1-x636.google.com with SMTP id\n d9443c01a7336-2a9296b3926so19326595ad.1\n for <qemu-ppc@nongnu.org>; Fri, 06 Feb 2026 14:19:18 -0800 (PST)", "from pc.taild8403c.ts.net (216-71-219-44.dyn.novuscom.net.\n [216.71.219.44]) by smtp.gmail.com with ESMTPSA id\n d9443c01a7336-2a95bff42f7sm13316575ad.68.2026.02.06.14.19.16\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Fri, 06 Feb 2026 14:19:17 -0800 (PST)" ], "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=linaro.org; s=google; t=1770416358; x=1771021158; darn=nongnu.org;\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=BDVf0HcSlG+DZgs/i7+uJFbsNebFbALD/dqSu3oQmMY=;\n b=FWa93Z951Eb2u1fBDn6S6eHd+nAiMmkqYM+ukrnk2YxDsKOv14cCRxPX0L2dNEHaKD\n nS0z9Z7l4wpj58GnieFXHH9tFi6I2Srnu+gWlGCME6L0BaDBVWLZ17MTpCBp0vuruFNR\n /KEcGf9Mq7dZ1yesuicJN9yhyf9XkbC+P6UiNXPH1wtWFDEh9KXtw9SjiFM7jHZvr2Ys\n fqpLaRMcJ4yY9hU7rSZd9sypt4YaAenPzm+aBGuvYi2Bv7O2MWjijita123Wnzpt70qx\n AbXzfys8JEvexmdP2UY89fsQHaGmP2g6AcwAshE/o/GMg6tj6ymrSeL6gYektyFKiMQn\n a7tA==", "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20230601; t=1770416358; x=1771021158;\n h=content-transfer-encoding:mime-version:references:in-reply-to\n :message-id:date:subject:cc:to:from:x-gm-gg:x-gm-message-state:from\n :to:cc:subject:date:message-id:reply-to;\n bh=BDVf0HcSlG+DZgs/i7+uJFbsNebFbALD/dqSu3oQmMY=;\n b=MkA4wjcuxeGSR5lOv0KjvNMehc4QFUfoShmy45kd7ag7rf/NsYByTCkolxndIKHK+R\n MHfYajMhibeUZcSsbYlIodkGLh+SiXa/LY8MQykVPy1bzrUMTG1M0ept2W9tjRdAgJER\n xM2K1HuwZP3+uC/JYSw8O+2sUOz+CXr4BA44LPSxIP9b9vkGIduQ9aq7+arpmmilDb9Y\n ONg8i2J82JeFfWmO4LZ4fk92Kj8hoIjlXnDRlGgSbD8KeSQOUoDuV77tMCrK/ZNnbJAz\n cNq3Rbf5rkm9wRe8avx1qC3gENNUDDUYg552h8fcC6AROAvBUQq5ljjj3dIfARvkbLqI\n vBgw==", "X-Forwarded-Encrypted": "i=1;\n AJvYcCVZmw9MDk8WBry0pc21gSDAFJGpKKV3Bj3yT1+Z28tJBH4rDKA/sTyIR5WGUlzEuG6ABunHQu/vFg==@nongnu.org", "X-Gm-Message-State": "AOJu0Ywx56kygD4xyGYvAtDpvgB6ZTSny/Ob0QjHS8DkoSPbOnqnG2dM\n 8vXoCLJuhXd3llCbcWQDV1fwzicsEF5Dx2GRGkmO44gaoZi/fk+et9Tc1uzkwh4rOdI=", "X-Gm-Gg": "AZuq6aI/Phe9cL4Dl7gjk3qkWQPNKvZDc0ksvSBswbJ/nxXf+mJqrxhr4SekbmdPSBx\n SIARE0U1IdGtq4GfNfYF5lXJHuI8xXicE4inqutGoSSyVXWcGhczbyg1o30xf/ihSCDDK9fWJ38\n hpVnTd7T8gKnNf23ijmDo9SJZmefES1UVLV62l4QmWLzCwd8YdAGh2/0JMcgh5UeBTfcVp+UQQ9\n u94JQ99F5pEs0AjbnO+TmBnScTqkbSn/0wwXRMc0iyNmxtz9VEHz2PCadVV6GxwSxDGmLlKabHX\n 6DKvrzw5bS/sJgqK5wYpDD1qcBjU8dqW+eQXTAtQ7UUJiRdDQWzp7t68pOxfA1czysZGHVxjHl9\n YPU3d5/vX223GEoqV8aramyfVzLBHzBYUZpEF1ZhipIx5BX+ikg+ojMDrlGjYNnon4KW5WlVjMw\n Y+Z/dLnqRzNxmncXMcunFrt0netW+gxy6xqjXvYggtwR2EX1w/TnNUf5vY/5G825K9wz6Unr7LU\n Ud5", "X-Received": "by 2002:a17:903:298b:b0:2a9:484c:ff21 with SMTP id\n d9443c01a7336-2a951666249mr45795875ad.25.1770416357498;\n Fri, 06 Feb 2026 14:19:17 -0800 (PST)", "From": "Pierrick Bouvier <pierrick.bouvier@linaro.org>", "To": "qemu-devel@nongnu.org", "Cc": "=?utf-8?q?Philippe_Mathieu-Daud=C3=A9?= <philmd@linaro.org>,\n Stefano Garzarella <sgarzare@redhat.com>,\n Nicholas Piggin <npiggin@gmail.com>,\n Harsh Prateek Bora <harshpb@linux.ibm.com>,\n \"Michael S. Tsirkin\" <mst@redhat.com>,\n Pierrick Bouvier <pierrick.bouvier@linaro.org>, stefanha@redhat.com,\n richard.henderson@linaro.org, qemu-ppc@nongnu.org", "Subject": "[PATCH v5 2/9] hw/virtio: Introduce\n VirtIODevice::access_is_big_endian boolean field", "Date": "Fri, 6 Feb 2026 14:19:01 -0800", "Message-ID": "<20260206221908.1451528-3-pierrick.bouvier@linaro.org>", "X-Mailer": "git-send-email 2.47.3", "In-Reply-To": "<20260206221908.1451528-1-pierrick.bouvier@linaro.org>", "References": "<20260206221908.1451528-1-pierrick.bouvier@linaro.org>", "MIME-Version": "1.0", "Content-Type": "text/plain; charset=UTF-8", "Content-Transfer-Encoding": "8bit", "Received-SPF": "pass client-ip=2607:f8b0:4864:20::636;\n envelope-from=pierrick.bouvier@linaro.org; helo=mail-pl1-x636.google.com", "X-Spam_score_int": "-20", "X-Spam_score": "-2.1", "X-Spam_bar": "--", "X-Spam_report": "(-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1,\n DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1,\n RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001,\n SPF_PASS=-0.001 autolearn=ham autolearn_force=no", "X-Spam_action": "no action", "X-BeenThere": "qemu-ppc@nongnu.org", "X-Mailman-Version": "2.1.29", "Precedence": "list", "List-Id": "<qemu-ppc.nongnu.org>", "List-Unsubscribe": "<https://lists.nongnu.org/mailman/options/qemu-ppc>,\n <mailto:qemu-ppc-request@nongnu.org?subject=unsubscribe>", "List-Archive": "<https://lists.nongnu.org/archive/html/qemu-ppc>", "List-Post": "<mailto:qemu-ppc@nongnu.org>", "List-Help": "<mailto:qemu-ppc-request@nongnu.org?subject=help>", "List-Subscribe": "<https://lists.nongnu.org/mailman/listinfo/qemu-ppc>,\n <mailto:qemu-ppc-request@nongnu.org?subject=subscribe>", "Errors-To": "qemu-ppc-bounces+incoming=patchwork.ozlabs.org@nongnu.org", "Sender": "qemu-ppc-bounces+incoming=patchwork.ozlabs.org@nongnu.org" }, "content": "From: Philippe Mathieu-Daudé <philmd@linaro.org>\n\nVirtIODevice::access_is_big_endian boolean field, initialized on device\nrealize, and updated when setting device features. This happens on reset\nor when configuring device after initial realize. It represents\nwhether load/store accesses are ordered using big endianness.\n\nSigned-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>\nSigned-off-by: Pierrick Bouvier <pierrick.bouvier@linaro.org>\n---\n include/hw/virtio/virtio.h | 5 +++++\n hw/virtio/virtio.c | 5 +++++\n 2 files changed, 10 insertions(+)", "diff": "diff --git a/include/hw/virtio/virtio.h b/include/hw/virtio/virtio.h\nindex 65872f2c54c..0f792e24f23 100644\n--- a/include/hw/virtio/virtio.h\n+++ b/include/hw/virtio/virtio.h\n@@ -154,6 +154,11 @@ struct VirtIODevice\n VMChangeStateEntry *vmstate;\n char *bus_name;\n uint8_t device_endian;\n+ /**\n+ * @access_is_big_endian: whether load/store memory accesses are ordered\n+ * using big endianness.\n+ */\n+ bool access_is_big_endian;\n /**\n * @user_guest_notifier_mask: gate usage of ->guest_notifier_mask() callback.\n * This is used to suppress the masking of guest updates for\ndiff --git a/hw/virtio/virtio.c b/hw/virtio/virtio.c\nindex 77ca54e5206..a429ff7de39 100644\n--- a/hw/virtio/virtio.c\n+++ b/hw/virtio/virtio.c\n@@ -3154,6 +3154,10 @@ static int virtio_set_features_nocheck(VirtIODevice *vdev, const uint64_t *val)\n }\n \n virtio_features_copy(vdev->guest_features_ex, tmp);\n+ if (!bad) {\n+ /* set_features might enable VIRTIO_F_VERSION_1 */\n+ vdev->access_is_big_endian = virtio_access_is_big_endian(vdev);\n+ }\n return bad ? -1 : 0;\n }\n \n@@ -4075,6 +4079,7 @@ static void virtio_device_realize(DeviceState *dev, Error **errp)\n vdev->listener.commit = virtio_memory_listener_commit;\n vdev->listener.name = \"virtio\";\n memory_listener_register(&vdev->listener, vdev->dma_as);\n+ vdev->access_is_big_endian = virtio_access_is_big_endian(vdev);\n }\n \n static void virtio_device_unrealize(DeviceState *dev)\n", "prefixes": [ "v5", "2/9" ] }