get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 2231477,
    "url": "http://patchwork.ozlabs.org/api/patches/2231477/?format=api",
    "web_url": "http://patchwork.ozlabs.org/project/qemu-devel/patch/ff0c870a705914ed4f5968802d398c24d19a13e7.1777571962.git.matyas.bobek@gmail.com/",
    "project": {
        "id": 14,
        "url": "http://patchwork.ozlabs.org/api/projects/14/?format=api",
        "name": "QEMU Development",
        "link_name": "qemu-devel",
        "list_id": "qemu-devel.nongnu.org",
        "list_email": "qemu-devel@nongnu.org",
        "web_url": "",
        "scm_url": "",
        "webscm_url": "",
        "list_archive_url": "",
        "list_archive_url_format": "",
        "commit_url_format": ""
    },
    "msgid": "<ff0c870a705914ed4f5968802d398c24d19a13e7.1777571962.git.matyas.bobek@gmail.com>",
    "list_archive_url": null,
    "date": "2026-04-30T18:26:04",
    "name": "[v3,2/7] hw/arm/sabrelite: Introduce class SabreliteMachineState",
    "commit_ref": null,
    "pull_url": null,
    "state": "new",
    "archived": false,
    "hash": "8f4224e8bd015e618072335702d1980e1fe807b4",
    "submitter": {
        "id": 92267,
        "url": "http://patchwork.ozlabs.org/api/people/92267/?format=api",
        "name": "Matyáš Bobek",
        "email": "matyas.bobek@gmail.com"
    },
    "delegate": null,
    "mbox": "http://patchwork.ozlabs.org/project/qemu-devel/patch/ff0c870a705914ed4f5968802d398c24d19a13e7.1777571962.git.matyas.bobek@gmail.com/mbox/",
    "series": [
        {
            "id": 502356,
            "url": "http://patchwork.ozlabs.org/api/series/502356/?format=api",
            "web_url": "http://patchwork.ozlabs.org/project/qemu-devel/list/?series=502356",
            "date": "2026-04-30T18:26:02",
            "name": "hw/arm/sabrelite: Add FlexCAN support",
            "version": 3,
            "mbox": "http://patchwork.ozlabs.org/series/502356/mbox/"
        }
    ],
    "comments": "http://patchwork.ozlabs.org/api/patches/2231477/comments/",
    "check": "pending",
    "checks": "http://patchwork.ozlabs.org/api/patches/2231477/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<qemu-devel-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=gmail.com header.i=@gmail.com header.a=rsa-sha256\n header.s=20251104 header.b=ROuLToVY;\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=lists1p.gnu.org;\n envelope-from=qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org;\n receiver=patchwork.ozlabs.org)"
        ],
        "Received": [
            "from lists1p.gnu.org (lists1p.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 4g62hx1WLgz1yHZ\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 01 May 2026 04:27:43 +1000 (AEST)",
            "from localhost ([::1] helo=lists1p.gnu.org)\n\tby lists1p.gnu.org with esmtp (Exim 4.90_1)\n\t(envelope-from <qemu-devel-bounces@nongnu.org>)\n\tid 1wIW6K-0006ah-M2; Thu, 30 Apr 2026 14:27:06 -0400",
            "from eggs.gnu.org ([2001:470:142:3::10])\n by lists1p.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <matyas.bobek@gmail.com>)\n id 1wIW5i-0006WC-9k\n for qemu-devel@nongnu.org; Thu, 30 Apr 2026 14:26:32 -0400",
            "from mail-wr1-x429.google.com ([2a00:1450:4864:20::429])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128)\n (Exim 4.90_1) (envelope-from <matyas.bobek@gmail.com>)\n id 1wIW5e-0005UM-Ce\n for qemu-devel@nongnu.org; Thu, 30 Apr 2026 14:26:25 -0400",
            "by mail-wr1-x429.google.com with SMTP id\n ffacd0b85a97d-43eb012ac4fso767734f8f.0\n for <qemu-devel@nongnu.org>; Thu, 30 Apr 2026 11:26:22 -0700 (PDT)",
            "from acidburn.pod.cvut.cz (acidburn.pod.cvut.cz. [147.32.90.2])\n by smtp.gmail.com with ESMTPSA id\n ffacd0b85a97d-447b76e5c00sm14674925f8f.25.2026.04.30.11.26.20\n (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256);\n Thu, 30 Apr 2026 11:26:20 -0700 (PDT)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=gmail.com; s=20251104; t=1777573581; x=1778178381; 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=30GY1IKrltrPVzUIuoJTA3lYJMRk3qcolQ/AgKSRsLY=;\n b=ROuLToVYu2IHpKwe+LPszGyHEl542kyI4l2UheRiiKK56gtyvWkPGGTIlFs67b7kg4\n 2EzYPbbddCLG/Zcjw8r4K18QKU80MtDIo1/g2ozKsx8SuVxEz1XAMAywA+lBTURXhp5E\n DiIWWK/HbFPDLTkO3Xl2RtpjLp3Zue0uqUporNFZINtzF6vyg7Nm6dA9PwPjA7jA/p2n\n jTTgf7Jdhfz/VlOw8p4IHEFPwlt1eLkrZ2JifgO2Ifmj2N61Gt+ge0coN5ng1PKItU83\n RHcmIvMtjMUpztpznWXYzfjY8M3mMAOlUh3WpatGNrveG/RMYpEORz/wufeHNh7x9r0a\n f3zg==",
        "X-Google-DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n d=1e100.net; s=20251104; t=1777573581; x=1778178381;\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=30GY1IKrltrPVzUIuoJTA3lYJMRk3qcolQ/AgKSRsLY=;\n b=lDM7JegFISsJWPdcGddqRTHHdUrAe/GV1UTeLdeixHeChB74BZEDODTcWAsVwgy8ZZ\n 0obHx8m/qT6rdvbZpp/Zls2v6h7n5q16Pk2k+Mhye8hGDFl75ERBEn0pXzPplWhxPII7\n yrBtO94DYJYWECPdOPYydhJ156d61gh+aLGHhL1IAzlq4BRIMUFPX/qGMIO7rxfldiWV\n La42ORwutfcyn/IfSojgA+dfnmwKEEWOv0IxO1oIqM+SCcNiJXxJvvQ2Hji0uJuCtNLK\n a6UvimTGbfdHqkow57djUUgNe76NgsOkQzX28F7m+rSjZ1bfseQLeNDWzGTucAUpnEtj\n hr7w==",
        "X-Gm-Message-State": "AOJu0YytwN3M4QbPqCujKHqEroDxyA6ur0SXKMDLY6uq8tnFqM6ZBQEQ\n KK1hYMgnP0094D2juuzC+ttp59GpvWqPNFvmpOGef/h3Vm4J8naV77FAO/9P5jJL",
        "X-Gm-Gg": "AeBDieu35dVzQg2wMmUBI0KJVdPzRa2KYQq1OknboS1qWyeBW0L+4ntqpHqGXMeckGF\n 1vDRxDM84zhPUYX4mkbReTDMwJY+DpQJSlEmLYr5kg+x8KFI/T72sSxf8Ue7FNL5nECfKy8z1OS\n nu2vfOTwpVewJftTfOvLjLVOSukQUAW9tYI3QyZLRBNWuyQ7akyCYUKdoKsxo5kG6CG9nZwAeVU\n 0BG+o7VwsIKRGO0eKvm67SuE/3/+3uGXbj2NNQbe72j8cKNye92TSWMTVsLYWiC7dHtcVHz7xV6\n z07qqvCYJVKwbrH3ZKBiSd5FIfkLqgw+UDla8Y2VHtGyVKxDImGwyEbzfnTdzOIrg2wOb0dIIUY\n a+3Tzl7XhJ0U0Y/+X9W/IyiBw8IyLq1RepYmZZh/XgwS/oFukPM8MnbmXHDcCmCM0dfR8nenifo\n 62lsNitb973DrmtfIdOrQcFCGDtEYOKZerhSoos67TPxnePB0UF+U3ZbaJH6tjnsy0",
        "X-Received": "by 2002:a05:6000:430a:b0:43d:e31:68d1 with SMTP id\n ffacd0b85a97d-4493ec61b5cmr7122353f8f.21.1777573580839;\n Thu, 30 Apr 2026 11:26:20 -0700 (PDT)",
        "From": "=?utf-8?b?TWF0ecOhxaEgQm9iZWs=?= <matyas.bobek@gmail.com>",
        "To": "qemu-devel@nongnu.org, Matyas Bobek <bobekmat@fel.cvut.cz>,\n Pavel Pisa <pisa@fel.cvut.cz>, Bernhard Beschow <shentey@gmail.com>",
        "Cc": "qemu-arm@nongnu.org, Marc Kleine-Budde <mkl@pengutronix.de>,\n Oliver Hartkopp <socketcan@hartkopp.net>,\n Nikita Ostrenkov <n.ostrenkov@gmail.com>,\n Peter Maydell <peter.maydell@linaro.org>,\n =?utf-8?b?TWF0ecOhxaEgQm9iZWs=?= <matyas.bobek@gmail.com>",
        "Subject": "[PATCH v3 2/7] hw/arm/sabrelite: Introduce class\n SabreliteMachineState",
        "Date": "Thu, 30 Apr 2026 20:26:04 +0200",
        "Message-ID": "\n <ff0c870a705914ed4f5968802d398c24d19a13e7.1777571962.git.matyas.bobek@gmail.com>",
        "X-Mailer": "git-send-email 2.53.0",
        "In-Reply-To": "<cover.1777571962.git.matyas.bobek@gmail.com>",
        "References": "<cover.1777571962.git.matyas.bobek@gmail.com>",
        "MIME-Version": "1.0",
        "Content-Type": "text/plain; charset=UTF-8",
        "Content-Transfer-Encoding": "8bit",
        "Received-SPF": "pass client-ip=2a00:1450:4864:20::429;\n envelope-from=matyas.bobek@gmail.com; helo=mail-wr1-x429.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, FREEMAIL_FROM=0.001,\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-devel@nongnu.org",
        "X-Mailman-Version": "2.1.29",
        "Precedence": "list",
        "List-Id": "qemu development <qemu-devel.nongnu.org>",
        "List-Unsubscribe": "<https://lists.nongnu.org/mailman/options/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=unsubscribe>",
        "List-Archive": "<https://lists.nongnu.org/archive/html/qemu-devel>",
        "List-Post": "<mailto:qemu-devel@nongnu.org>",
        "List-Help": "<mailto:qemu-devel-request@nongnu.org?subject=help>",
        "List-Subscribe": "<https://lists.nongnu.org/mailman/listinfo/qemu-devel>,\n <mailto:qemu-devel-request@nongnu.org?subject=subscribe>",
        "Errors-To": "qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org",
        "Sender": "qemu-devel-bounces+incoming=patchwork.ozlabs.org@nongnu.org"
    },
    "content": "Create full class SabreliteMachineState extending MachineState.\n\nPreviously, Sabrelite board MachineState was declared indirectly by the\nDEFINE_MACHINE_ARM macro. FslIMX6State was only instantiated in the\nsabrelite_init function. For FlexCAN device, machine properties\nwill be used to select QEMU CAN buses. A custom class is therefore\nrequired, so the CanBusState \"connections\" can then be added as fields.\n\nSigned-off-by: Matyáš Bobek <matyas.bobek@gmail.com>\nSigned-off-by: Pavel Pisa <pisa@fel.cvut.cz>\nTested-by: Pavel Pisa <pisa@fel.cvut.cz>\nReviewed-by: Bernhard Beschow <shentey@gmail.com>\nReviewed-by: Pavel Pisa <pisa@fel.cvut.cz>\n---\n hw/arm/sabrelite.c | 28 ++++++++++++++++++----------\n 1 file changed, 18 insertions(+), 10 deletions(-)",
    "diff": "diff --git a/hw/arm/sabrelite.c b/hw/arm/sabrelite.c\nindex 04484aaa14..7e036e6388 100644\n--- a/hw/arm/sabrelite.c\n+++ b/hw/arm/sabrelite.c\n@@ -20,6 +20,15 @@\n #include \"qemu/error-report.h\"\n #include \"system/qtest.h\"\n \n+struct SabreliteMachineState {\n+    MachineState parent_obj;\n+\n+    FslIMX6State soc;\n+};\n+\n+#define TYPE_SABRELITE_MACHINE MACHINE_TYPE_NAME(\"sabrelite\")\n+OBJECT_DECLARE_SIMPLE_TYPE(SabreliteMachineState, SABRELITE_MACHINE)\n+\n static struct arm_boot_info sabrelite_binfo = {\n     /* DDR memory start */\n     .loader_start = FSL_IMX6_MMDC_ADDR,\n@@ -41,7 +50,7 @@ static void sabrelite_reset_secondary(ARMCPU *cpu,\n \n static void sabrelite_init(MachineState *machine)\n {\n-    FslIMX6State *s;\n+    SabreliteMachineState *s = SABRELITE_MACHINE(machine);\n \n     /* Check the amount of memory is compatible with the SOC */\n     if (machine->ram_size > FSL_IMX6_MMDC_SIZE) {\n@@ -50,13 +59,12 @@ static void sabrelite_init(MachineState *machine)\n         exit(1);\n     }\n \n-    s = FSL_IMX6(object_new(TYPE_FSL_IMX6));\n-    object_property_add_child(OBJECT(machine), \"soc\", OBJECT(s));\n+    object_initialize_child(OBJECT(machine), \"soc\", &s->soc, TYPE_FSL_IMX6);\n \n     /* Ethernet PHY address is 6 */\n-    object_property_set_int(OBJECT(s), \"fec-phy-num\", 6, &error_fatal);\n+    object_property_set_int(OBJECT(&s->soc), \"fec-phy-num\", 6, &error_fatal);\n \n-    qdev_realize(DEVICE(s), NULL, &error_fatal);\n+    qdev_realize(DEVICE(&s->soc), NULL, &error_fatal);\n \n     memory_region_add_subregion(get_system_memory(), FSL_IMX6_MMDC_ADDR,\n                                 machine->ram);\n@@ -70,7 +78,7 @@ static void sabrelite_init(MachineState *machine)\n         /* Add the sst25vf016b NOR FLASH memory to first SPI */\n         Object *spi_dev;\n \n-        spi_dev = object_resolve_path_component(OBJECT(s), \"spi1\");\n+        spi_dev = object_resolve_path_component(OBJECT(&s->soc), \"spi1\");\n         if (spi_dev) {\n             SSIBus *spi_bus;\n \n@@ -89,7 +97,7 @@ static void sabrelite_init(MachineState *machine)\n                 qdev_realize_and_unref(flash_dev, BUS(spi_bus), &error_fatal);\n \n                 cs_line = qdev_get_gpio_in_named(flash_dev, SSI_GPIO_CS, 0);\n-                qdev_connect_gpio_out(DEVICE(&s->gpio[2]), 19, cs_line);\n+                qdev_connect_gpio_out(DEVICE(&s->soc.gpio[2]), 19, cs_line);\n             }\n         }\n     }\n@@ -100,7 +108,7 @@ static void sabrelite_init(MachineState *machine)\n     sabrelite_binfo.secondary_cpu_reset_hook = sabrelite_reset_secondary;\n \n     if (!qtest_enabled()) {\n-        arm_load_kernel(&s->cpu[0], machine, &sabrelite_binfo);\n+        arm_load_kernel(&s->soc.cpu[0], machine, &sabrelite_binfo);\n     }\n }\n \n@@ -117,10 +125,10 @@ static void sabrelite_machine_class_init(ObjectClass *oc, const void *data)\n }\n \n static const TypeInfo sabrelite_machine_init_typeinfo = {\n-    .name          = MACHINE_TYPE_NAME(\"sabrelite\"),\n+    .name          = TYPE_SABRELITE_MACHINE,\n     .parent        = TYPE_MACHINE,\n     .class_init    = sabrelite_machine_class_init,\n-    .instance_size = sizeof(MachineState),\n+    .instance_size = sizeof(SabreliteMachineState),\n     .abstract      = false,\n     .interfaces    = arm_machine_interfaces,\n };\n",
    "prefixes": [
        "v3",
        "2/7"
    ]
}