get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 2224198,
    "url": "http://patchwork.ozlabs.org/api/1.2/patches/2224198/?format=api",
    "web_url": "http://patchwork.ozlabs.org/project/qemu-devel/patch/20260417032837.2664122-19-jamin_lin@aspeedtech.com/",
    "project": {
        "id": 14,
        "url": "http://patchwork.ozlabs.org/api/1.2/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": "<20260417032837.2664122-19-jamin_lin@aspeedtech.com>",
    "list_archive_url": null,
    "date": "2026-04-17T03:29:02",
    "name": "[v4,18/21] hw/arm/ast27x0: Share single SCUIO instance across PSP, SSP, and TSP",
    "commit_ref": null,
    "pull_url": null,
    "state": "new",
    "archived": false,
    "hash": "ed8fbd477cc2e76d58859b4575e21b21caecd837",
    "submitter": {
        "id": 81768,
        "url": "http://patchwork.ozlabs.org/api/1.2/people/81768/?format=api",
        "name": "Jamin Lin",
        "email": "jamin_lin@aspeedtech.com"
    },
    "delegate": null,
    "mbox": "http://patchwork.ozlabs.org/project/qemu-devel/patch/20260417032837.2664122-19-jamin_lin@aspeedtech.com/mbox/",
    "series": [
        {
            "id": 500228,
            "url": "http://patchwork.ozlabs.org/api/1.2/series/500228/?format=api",
            "web_url": "http://patchwork.ozlabs.org/project/qemu-devel/list/?series=500228",
            "date": "2026-04-17T03:28:41",
            "name": "Add SSP/TSP power control and DRAM remap support for AST2700",
            "version": 4,
            "mbox": "http://patchwork.ozlabs.org/series/500228/mbox/"
        }
    ],
    "comments": "http://patchwork.ozlabs.org/api/patches/2224198/comments/",
    "check": "pending",
    "checks": "http://patchwork.ozlabs.org/api/patches/2224198/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=aspeedtech.com header.i=@aspeedtech.com\n header.a=rsa-sha256 header.s=selector1 header.b=ILarq7Jx;\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)",
            "dkim=none (message not signed)\n header.d=none;dmarc=none action=none header.from=aspeedtech.com;"
        ],
        "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 4fxgS41TRlz1yD3\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 17 Apr 2026 13:32:36 +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 1wDZta-0002fB-Ex; Thu, 16 Apr 2026 23:29:30 -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 <jamin_lin@aspeedtech.com>)\n id 1wDZtL-0002PD-Dq; Thu, 16 Apr 2026 23:29:16 -0400",
            "from mail-koreacentralazlp170130006.outbound.protection.outlook.com\n ([2a01:111:f403:c40f::6] helo=SEYPR02CU001.outbound.protection.outlook.com)\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <jamin_lin@aspeedtech.com>)\n id 1wDZtJ-0005tG-Hp; Thu, 16 Apr 2026 23:29:15 -0400",
            "from TYPPR06MB8206.apcprd06.prod.outlook.com (2603:1096:405:383::19)\n by KUZPR06MB8076.apcprd06.prod.outlook.com (2603:1096:d10:43::13)\n with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9818.25; Fri, 17 Apr\n 2026 03:29:02 +0000",
            "from TYPPR06MB8206.apcprd06.prod.outlook.com\n ([fe80::e659:1ead:77cb:f6d3]) by TYPPR06MB8206.apcprd06.prod.outlook.com\n ([fe80::e659:1ead:77cb:f6d3%3]) with mapi id 15.20.9818.023; Fri, 17 Apr 2026\n 03:29:02 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none;\n b=kM4rvUS0uE411c30dfQVSwm/+p5pWWplU0gmuzDMk1P7GN6ScXeeuM6S8hDR5rSoe9NjEuQcY3ljOuZwlttEKkyFy/2xANMeFUrfOk+Ck5vzvNiCnliPQmbmvLRukeJaxCk/87PA3ApPPHTzZBbJ4Hgh8z81dZ3OWaQSipsZzzfDS3CCY3QRfEk1wocEbmungLVVsRoQWsOtdXpS6wVrOITyqrDJsK5g33ELWHZDbxlCuZrBMFzmBxdw/bpwQsVUdRZ48SKbIinA3uD5Q9mMqmTU44DWqTRo6lUOLlFuWHjOcecOjyZegi3YhP3tIyHHuSsmN+M3ehPPwcWP0/eiGA==",
        "ARC-Message-Signature": "i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n s=arcselector10001;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1;\n bh=04PwlUO/BubAURcLwbcrB9F563KOOUB9mK7onbOxn5s=;\n b=Xjglp2fLkQAEZUdFvTrezL1FwATdhlwNdXs+VdstXgi9UsejK5izHVwevbJBfSwXNUOHGjurAuHJmZpBZoKKS9hsuxOTmfmgZFPCTlCXyqlGcYGE9N3VTIZicO1RvVqjd+a/Oc6D6XVaysj03aijwvpkjTvjRGYr++tGT72FYvJmsUtZaDXUzBBEWjAJWgIJjznWk2hclgUg4nxXCBmaTj+hw0zeawEr3hFp8M9+AJAcr6yRZWhJkz8x2vmBOo21HOFaJD7GWgREW/ujmFUYKBRejOhkuLfSnCuxtVIlY8iDDN5KiOe3d5zyGuPBTeuseotZc5zR4nM/g4xQ9Bj3Jw==",
        "ARC-Authentication-Results": "i=1; mx.microsoft.com 1; spf=pass\n smtp.mailfrom=aspeedtech.com; dmarc=pass action=none\n header.from=aspeedtech.com; dkim=pass header.d=aspeedtech.com; arc=none",
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=aspeedtech.com;\n s=selector1;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=04PwlUO/BubAURcLwbcrB9F563KOOUB9mK7onbOxn5s=;\n b=ILarq7JxeJSPAQbsmGr3E15pb15TsA+jQEelW+wgmT34aTLWbzfnqxqOE0eXDmNjak5UIPoWvSwyMSiJpZnpK2beQ3z1+I2+9YD4KEuor77Qr2ABMwFzJo2zI/8T1a9eR/On9cUZp7ZAbov1vU/yyB5dPl4mgEBpWpdHjugXP/Pju2tKw4ReZmGrhxUyuJdafIM69qOYjgvTks4j07/SPVrXfiJyW3oqggxlXO00YXTOFeQTplmKlBC929OU/ivEjkpQUzmbEMPIS1qDaulo2uCQVgFaGo1J3ExDylxociuF1uMaLR3ZD9v55RbjyojrsIxDSZ5vr6h/WVjRQKaBdw==",
        "From": "Jamin Lin <jamin_lin@aspeedtech.com>",
        "To": "=?windows-1252?q?C=E9dric_Le_Goater?= <clg@kaod.org>,\n Peter Maydell <peter.maydell@linaro.org>,\n Steven Lee <steven_lee@aspeedtech.com>, Troy Lee <leetroy@gmail.com>,\n Kane Chen <kane_chen@aspeedtech.com>,\n Andrew Jeffery <andrew@codeconstruct.com.au>, Joel Stanley <joel@jms.id.au>,\n Pierrick Bouvier <pierrick.bouvier@linaro.org>,\n Alistair Francis <alistair@alistair23.me>, Kevin Wolf <kwolf@redhat.com>,\n Hanna Reitz <hreitz@redhat.com>,\n \"open list:ASPEED BMCs\" <qemu-arm@nongnu.org>,\n \"open list:All patches CC here\" <qemu-devel@nongnu.org>,\n \"open list:Block layer core\" <qemu-block@nongnu.org>",
        "CC": "Jamin Lin <jamin_lin@aspeedtech.com>, Troy Lee <troy_lee@aspeedtech.com>",
        "Subject": "[PATCH v4 18/21] hw/arm/ast27x0: Share single SCUIO instance across\n PSP, SSP, and TSP",
        "Thread-Topic": "[PATCH v4 18/21] hw/arm/ast27x0: Share single SCUIO instance\n across PSP, SSP, and TSP",
        "Thread-Index": "AQHczhpWpaIQjJL2qkyBZ0SmmuHXHw==",
        "Date": "Fri, 17 Apr 2026 03:29:02 +0000",
        "Message-ID": "<20260417032837.2664122-19-jamin_lin@aspeedtech.com>",
        "References": "<20260417032837.2664122-1-jamin_lin@aspeedtech.com>",
        "In-Reply-To": "<20260417032837.2664122-1-jamin_lin@aspeedtech.com>",
        "Accept-Language": "zh-TW, en-US",
        "Content-Language": "en-US",
        "X-MS-Has-Attach": "",
        "X-MS-TNEF-Correlator": "",
        "authentication-results": [
            "legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=aspeedtech.com header.i=@aspeedtech.com\n header.a=rsa-sha256 header.s=selector1 header.b=ILarq7Jx;\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)",
            "dkim=none (message not signed)\n header.d=none;dmarc=none action=none header.from=aspeedtech.com;"
        ],
        "x-ms-publictraffictype": "Email",
        "x-ms-traffictypediagnostic": "TYPPR06MB8206:EE_|KUZPR06MB8076:EE_",
        "x-ms-office365-filtering-correlation-id": "cb4e3318-544d-4a45-9e5b-08de9c3178a6",
        "x-ms-exchange-senderadcheck": "1",
        "x-ms-exchange-antispam-relay": "0",
        "x-microsoft-antispam": "BCL:0;\n ARA:13230040|1800799024|366016|376014|7416014|38070700021|921020|18002099003|22082099003|56012099003;",
        "x-microsoft-antispam-message-info": "\n lJFd0ptxt+0jrKjz0mmrJ7yR0E7webE3fJRIP+pKulmafSXRMi8wMIKxeorAhrOLXHC9WLkh+ODzxztaNFJAiaHuyx4rCLLyE1yuP/g1atiK3QAQtB7/xzUnCVdUofkRKgCbuDEARk5nDqAd8e0JxB6hzh7hG/D5vDhey1XOpgAm0v+m1U6xkjvfThkzRE2JJVmFPaVONvzUJtgQoi5gdUub3+ZdqnKD0eT0Di+UI1vKeUdIPp8l+I5u9mDPxWkhJjAxKv691vtmwMX3Qi6qsa3ZVBjznfGJgBGRQGVQvgvwCBHMJgHcC19XcJcDVT3YrOxtIoEPSwg71Y7VIQtcpqSHOGtT9ewAUeOSqH81aR7hCMADYLbQkk2r7InTSTF19JkFgMhy3VcLKIvk3+7mjew8AK0i0ZJ7JGsHF+8b/I7lxSV9D+GU1BRtnozGrA/mOl+UNfk2hxHGb3kKKK1f3Lh0lXGf29hzOgCcRxEAQFonyQrlvyEQB4iqH9M51piSgLnSMJZgh1gjijMU439FV/UQAlrTc5qDWVhFuBfr8cTPY3Jko/W5ccCAtNISYcABOhiZ7EuSxiVNGtbtATuPNgZ4oqY9hImQr+DodabKa1MWUCSAh4/qJf7/HKP1i0SO5vaNBm8iw4VFNKhMbEpHaVUJvrZ/BHlJL048g7TRX/YoZFuEAOZMwrKV4PzdLEn0imiEJTLxPiFuSE6CFoD6f6YvzlRW1cEqCyCy+CT4ceHMtOPYOL0hsU8YkuOygunnT1Y+maQ6VdGWnyuiPioFVfNrNqG+/B7fuvQHmf+O1ZnrGD7h4qqORjm+QwdcXgHg",
        "x-forefront-antispam-report": "CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:;\n IPV:NLI; SFV:NSPM; H:TYPPR06MB8206.apcprd06.prod.outlook.com; PTR:; CAT:NONE;\n SFS:(13230040)(1800799024)(366016)(376014)(7416014)(38070700021)(921020)(18002099003)(22082099003)(56012099003);\n DIR:OUT; SFP:1102;",
        "x-ms-exchange-antispam-messagedata-chunkcount": "1",
        "x-ms-exchange-antispam-messagedata-0": "=?windows-1252?q?qb8ENnaVICruGSvB+2zsK?=\n\t=?windows-1252?q?lQV68EcTpJWbx3BDWcesUSwvgwCPCSFO1q4qVvyHt+atfjH13SRQPwUy0o?=\n\t=?windows-1252?q?mK4NlYAEoaJuvJIUULPyypA02tq6kCoG04AjGzqUxgBvoPRsUe0shzmDDj?=\n\t=?windows-1252?q?cvsejX1V99F3wvvwIksL/ME1Q41TynTNhXGuaIN2Bz+tFwvHccnspeLGzV?=\n\t=?windows-1252?q?IgLwni6gk+qmmG5DQW80wiJlwc3QTkoTphVkTWoA4NwphjbA0gNWuGBxYt?=\n\t=?windows-1252?q?5VOGNHFdw1FNXoSPLvIMnyxH5Gx1VCz/l2QfuueEj3b0w3U2lgyLgiNg7o?=\n\t=?windows-1252?q?9knxZJTGhBslgnD0CQQCPgcA4Kbvt2CP2rQj+q5vQcDnejd6NnkCNLf+e2?=\n\t=?windows-1252?q?bjgjISrOLvW/tAWHxqshTA9xGV7XmgEHyC4vKWIrI9lq1Y3MR79//JmW+V?=\n\t=?windows-1252?q?2t26QxJ9lGQO8NRYOx3jMta1OoNW/nYTRJgRULIjSdU8ea7JnLYwWLyYe/?=\n\t=?windows-1252?q?aynAC69HZO6CWCqt4GQtKyXMchoUgSztTp51HFOijqspsJnKW/+2ivdOnb?=\n\t=?windows-1252?q?4sm47t+4SrdPQ/VPaC9ikhnoMxpwstcJz9WIM3FkAB4sCLogH3hmBUxDxB?=\n\t=?windows-1252?q?IADNfMIMNMSfNOV2NlmRq43QEhBFKxg9dulpoJIjW0MA0Bk7FxvRq38qYj?=\n\t=?windows-1252?q?BKHwbfGWgs0jxsLXdv5M4BDi4NKOH8Vf/hHGl2+qlGy8v3FJp+ZYh8a9tV?=\n\t=?windows-1252?q?QMGq2WLvSCIXY4zsdLqQbp8wuICTVVr8D58JPhj4RhQB2f26Z3xS5OJPXi?=\n\t=?windows-1252?q?lgemi6H70+ZdV0wLRnoBbvRLJTDFrqOFTHyiakQd9wT1ELE1i++J1CgnmA?=\n\t=?windows-1252?q?Lv4r+1tKquevkOOus9a2LPmtNbb5gV1B/aQeZRqUGSZsWa/tAIwdIFheTw?=\n\t=?windows-1252?q?Y62cz3HQmvfiuyQebvlYL4fDgB97mPH4bsQr+PZS5kTBhTE7m9iAA8K3eL?=\n\t=?windows-1252?q?eoQQhDwav6rtVh8wk3MF/3uciJZLyTy0RaDVEynI0PaAilurTCY4GlKEaT?=\n\t=?windows-1252?q?uFIv/ES5nz9KUzIx7lCj9b2iRWoZD6bN4c9Br0fhDCDLlT9GWX1uK2xRBE?=\n\t=?windows-1252?q?sP8sc5Zz795dnaYNaxV3zNL7vtLp7u6BKWHnz5wMpzL45ebXma71Lbukzk?=\n\t=?windows-1252?q?xCRTkHDCgU8yNcxIDaq2YNsuzfthG/jBvjl87/+LmpO9GVA2qjeTx0AllJ?=\n\t=?windows-1252?q?U/+KOOjtJ0isZ1wek2bspVB35E/1cFJiwu1Hlk0iaU7CC/Efzcm1TNeP6p?=\n\t=?windows-1252?q?mF1IM+posC37f1ugK7ADSL+QPlxqZbhfTINSHrToIwIqwYQ+q1A+DXVF8c?=\n\t=?windows-1252?q?rYbU1yQv8ah/rqkUac7JLiizAfoOe+6rtrhBLuul+acP5zNgs5mzeYFZjd?=\n\t=?windows-1252?q?F6CSzdF9+AX0qfwLZAYvSa2xOkljw4y3uxL9hkc0S9JBDqweaQoIExFbGt?=\n\t=?windows-1252?q?QDjFRYZ2qhp40Yn9+AzRN3ovdgVBBhArSZVYDhWhLbmcnt9PIH/aJeyKHV?=\n\t=?windows-1252?q?Ts++XBg7uBYuvxNkf8/vongMqirm1pwU/zg3KlHY1RzQMAKPx1fSVEVJ0z?=\n\t=?windows-1252?q?m6EY90/ubpDfN/bPaVPNBgRfhAZS4cOccbcz3bHAxnRteuLmFUfmB4MFnR?=\n\t=?windows-1252?q?LMsbk2iEuOokKOLKGlUcD1T52LMxYeFb2SzI9XS1EwVSpFlLBX1fOD5h8N?=\n\t=?windows-1252?q?mBAgIb9qC+2tDD59GuPQswv05uaJ9xw5YhARSF7pQQSuzSnHHTXJ36mu2z?=\n\t=?windows-1252?q?ijwNL/1XEtH/F8/8/zWLus8RRU9YmQfC9nLIdMi/iIP1fzQ=3D=3D?=",
        "Content-Type": "text/plain; charset=\"Windows-1252\"",
        "Content-Transfer-Encoding": "quoted-printable",
        "MIME-Version": "1.0",
        "X-Exchange-RoutingPolicyChecked": "\n vgoZwwpUXr/AVESK64l6kBquN65EVY0ylf9obfFH/7D4I2sXWio4+UYrRvmkm8Br9OkoWHo6QhMCtlQyrwdqiDazg+815u8KInejuGf703bYD3FYDL1IkuvGBo9wWtF1MzUVjsGBYj4C9lFSUKb2K6GqUQC5nPOYvF8zHF1uiwhkxl3D/eO9B323EyHNm0ABqENf4lApX6h1F48+tQD4uUuQZ8pbcHTuNT5wAmtDPYtsAvwTZXIViXAjewb/9QL2OuG21eU3ev/E0tkrLUgZLOGmMObYVygE4J+wDio0V0FIwrq85pNx+QQU9SiKNwxcmqedvyDnchQjB4xpUcK45A==",
        "X-OriginatorOrg": "aspeedtech.com",
        "X-MS-Exchange-CrossTenant-AuthAs": "Internal",
        "X-MS-Exchange-CrossTenant-AuthSource": "TYPPR06MB8206.apcprd06.prod.outlook.com",
        "X-MS-Exchange-CrossTenant-Network-Message-Id": "\n cb4e3318-544d-4a45-9e5b-08de9c3178a6",
        "X-MS-Exchange-CrossTenant-originalarrivaltime": "17 Apr 2026 03:29:02.4069 (UTC)",
        "X-MS-Exchange-CrossTenant-fromentityheader": "Hosted",
        "X-MS-Exchange-CrossTenant-id": "43d4aa98-e35b-4575-8939-080e90d5a249",
        "X-MS-Exchange-CrossTenant-mailboxtype": "HOSTED",
        "X-MS-Exchange-CrossTenant-userprincipalname": "\n oJ859lWe01igD+HwPoStmkug3hmbUpU0loXxnescUQV+SHzT9WYvRpdoZlx9zUNXxXZZRBrwqKoTJmRINmzYb0oaNKW2rLQDWVI5aKXFMzY=",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "KUZPR06MB8076",
        "Received-SPF": "pass client-ip=2a01:111:f403:c40f::6;\n envelope-from=jamin_lin@aspeedtech.com;\n helo=SEYPR02CU001.outbound.protection.outlook.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 SPF_HELO_PASS=-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": "AST2700 has a single SCUIO hardware block, memory-mapped at\n0x14C02000–0x14C03FFF from the perspective of the main CA35 processor (PSP).\nThe SSP and TSP coprocessors access this same SCUIO block at different\naddresses: 0x74C02000–0x74C03FFF.\n\nPreviously, each subsystem (PSP, SSP, and TSP) instantiated its own SCUIO\ndevice, resulting in three independent SCUIO instances in the QEMU model.\nIn real hardware, however, only a single SCUIO exists and is shared among\nall processors.\n\nThis commit reworks the SCUIO model to correctly reflect the hardware\nbehavior by allowing SSP and TSP to reference the PSP’s SCUIO instance.\nThe following changes are introduced:\n\n- Add a scuio property to Aspeed27x0CoprocessorState for linking the\n  coprocessor to the PSP’s SCUIO instance.\n- Replace per-coprocessor SCUIO instantiation with a shared SCUIO link.\n- Add \"MemoryRegion scuio_alias\" to model address remapping for SSP and TSP.\n- Create SCUIO alias regions in both SSP and TSP coprocessors and map\n  them at 0x74C02000 to mirror the PSP’s SCUIO registers.\n- Ensure the SCUIO device in PSP is realized before SSP/TSP alias setup.\n\nWith this change, PSP, SSP, and TSP now share a consistent SCUIO state,\nmatching the single-SCUIO hardware design of AST2700.\n\nSigned-off-by: Jamin Lin <jamin_lin@aspeedtech.com>\n---\n include/hw/arm/aspeed_coprocessor.h |  4 ++--\n hw/arm/aspeed_ast27x0-fc.c          |  4 ++++\n hw/arm/aspeed_ast27x0-ssp.c         | 14 +++++++++-----\n hw/arm/aspeed_ast27x0-tsp.c         | 14 +++++++++-----\n 4 files changed, 24 insertions(+), 12 deletions(-)",
    "diff": "diff --git a/include/hw/arm/aspeed_coprocessor.h b/include/hw/arm/aspeed_coprocessor.h\nindex 7750569eed..23c3b97f06 100644\n--- a/include/hw/arm/aspeed_coprocessor.h\n+++ b/include/hw/arm/aspeed_coprocessor.h\n@@ -22,7 +22,6 @@ struct AspeedCoprocessorState {\n     MemoryRegion uart_alias;\n     Clock *sysclk;\n \n-    AspeedSCUState scuio;\n     AspeedTimerCtrlState timerctrl;\n     SerialMM *uart;\n     int uart_dev;\n@@ -45,15 +44,16 @@ struct Aspeed27x0CoprocessorState {\n     AspeedCoprocessorState parent;\n     AspeedINTCState intc[2];\n     UnimplementedDeviceState ipc[2];\n-    UnimplementedDeviceState scuio;\n     UnimplementedDeviceState pric[2];\n     UnimplementedDeviceState otp;\n \n     ARMv7MState armv7m;\n \n     MemoryRegion scu_alias;\n+    MemoryRegion scuio_alias;\n     MemoryRegion fmc_alias;\n     Aspeed2700SCUState *scu;\n+    AspeedSCUState *scuio;\n     AspeedSMCState *fmc;\n };\n \ndiff --git a/hw/arm/aspeed_ast27x0-fc.c b/hw/arm/aspeed_ast27x0-fc.c\nindex 56dd86e2c2..d1ff6fbd4d 100644\n--- a/hw/arm/aspeed_ast27x0-fc.c\n+++ b/hw/arm/aspeed_ast27x0-fc.c\n@@ -161,6 +161,8 @@ static bool ast2700fc_ssp_init(MachineState *machine, Error **errp)\n                              OBJECT(&psp->sram), &error_abort);\n     object_property_set_link(OBJECT(&s->ssp), \"scu\",\n                              OBJECT(&s->ca35.scu), &error_abort);\n+    object_property_set_link(OBJECT(&s->ssp), \"scuio\",\n+                             OBJECT(&psp->scuio), &error_abort);\n     object_property_set_link(OBJECT(&s->ssp), \"fmc\",\n                              OBJECT(&psp->fmc), &error_abort);\n     if (!qdev_realize(DEVICE(&s->ssp), NULL, errp)) {\n@@ -195,6 +197,8 @@ static bool ast2700fc_tsp_init(MachineState *machine, Error **errp)\n                              OBJECT(&psp->sram), &error_abort);\n     object_property_set_link(OBJECT(&s->tsp), \"scu\",\n                              OBJECT(&s->ca35.scu), &error_abort);\n+    object_property_set_link(OBJECT(&s->tsp), \"scuio\",\n+                             OBJECT(&psp->scuio), &error_abort);\n     object_property_set_link(OBJECT(&s->tsp), \"fmc\",\n                              OBJECT(&psp->fmc), &error_abort);\n     if (!qdev_realize(DEVICE(&s->tsp), NULL, errp)) {\ndiff --git a/hw/arm/aspeed_ast27x0-ssp.c b/hw/arm/aspeed_ast27x0-ssp.c\nindex 78bd6f342c..6c8945ce6c 100644\n--- a/hw/arm/aspeed_ast27x0-ssp.c\n+++ b/hw/arm/aspeed_ast27x0-ssp.c\n@@ -143,8 +143,6 @@ static void aspeed_soc_ast27x0ssp_init(Object *obj)\n                             TYPE_UNIMPLEMENTED_DEVICE);\n     object_initialize_child(obj, \"ipc1\", &a->ipc[1],\n                             TYPE_UNIMPLEMENTED_DEVICE);\n-    object_initialize_child(obj, \"scuio\", &a->scuio,\n-                            TYPE_UNIMPLEMENTED_DEVICE);\n     object_initialize_child(obj, \"pric0\", &a->pric[0],\n                             TYPE_UNIMPLEMENTED_DEVICE);\n     object_initialize_child(obj, \"pric1\", &a->pric[1],\n@@ -215,6 +213,13 @@ static void aspeed_soc_ast27x0ssp_realize(DeviceState *dev_soc, Error **errp)\n             memory_region_size(&a->scu->dram_remap_alias[1]),\n             &a->scu->dram_remap_alias[0]);\n \n+    /* SCUIO */\n+    memory_region_init_alias(&a->scuio_alias, OBJECT(a), \"scuio.alias\",\n+                             &a->scuio->iomem, 0,\n+                             memory_region_size(&a->scuio->iomem));\n+    memory_region_add_subregion(s->memory, sc->memmap[ASPEED_DEV_SCUIO],\n+                                &a->scuio_alias);\n+\n     /* INTC */\n     if (!sysbus_realize(SYS_BUS_DEVICE(&a->intc[0]), errp)) {\n         return;\n@@ -282,9 +287,6 @@ static void aspeed_soc_ast27x0ssp_realize(DeviceState *dev_soc, Error **errp)\n     aspeed_mmio_map_unimplemented(s->memory, SYS_BUS_DEVICE(&a->ipc[1]),\n                                   \"aspeed.ipc1\",\n                                   sc->memmap[ASPEED_DEV_IPC1], 0x1000);\n-    aspeed_mmio_map_unimplemented(s->memory, SYS_BUS_DEVICE(&a->scuio),\n-                                  \"aspeed.scuio\",\n-                                  sc->memmap[ASPEED_DEV_SCUIO], 0x1000);\n     aspeed_mmio_map_unimplemented(s->memory, SYS_BUS_DEVICE(&a->pric[0]),\n                                   \"aspeed.pric0\",\n                                   sc->memmap[ASPEED_DEV_PRIC0], 0x1000);\n@@ -299,6 +301,8 @@ static void aspeed_soc_ast27x0ssp_realize(DeviceState *dev_soc, Error **errp)\n static const Property aspeed_27x0_coprocessor_properties[] = {\n     DEFINE_PROP_LINK(\"scu\", Aspeed27x0CoprocessorState, scu,\n                      TYPE_ASPEED_2700_SCU, Aspeed2700SCUState *),\n+    DEFINE_PROP_LINK(\"scuio\", Aspeed27x0CoprocessorState, scuio,\n+                     TYPE_ASPEED_SCU, AspeedSCUState *),\n     DEFINE_PROP_LINK(\"fmc\", Aspeed27x0CoprocessorState, fmc, TYPE_ASPEED_SMC,\n                      AspeedSMCState *),\n };\ndiff --git a/hw/arm/aspeed_ast27x0-tsp.c b/hw/arm/aspeed_ast27x0-tsp.c\nindex d6448d82f5..cab7f47ac8 100644\n--- a/hw/arm/aspeed_ast27x0-tsp.c\n+++ b/hw/arm/aspeed_ast27x0-tsp.c\n@@ -143,8 +143,6 @@ static void aspeed_soc_ast27x0tsp_init(Object *obj)\n                             TYPE_UNIMPLEMENTED_DEVICE);\n     object_initialize_child(obj, \"ipc1\", &a->ipc[1],\n                             TYPE_UNIMPLEMENTED_DEVICE);\n-    object_initialize_child(obj, \"scuio\", &a->scuio,\n-                            TYPE_UNIMPLEMENTED_DEVICE);\n     object_initialize_child(obj, \"pric0\", &a->pric[0],\n                             TYPE_UNIMPLEMENTED_DEVICE);\n     object_initialize_child(obj, \"pric1\", &a->pric[1],\n@@ -212,6 +210,13 @@ static void aspeed_soc_ast27x0tsp_realize(DeviceState *dev_soc, Error **errp)\n     /* SDRAM remap alias used by PSP to access TSP SDRAM */\n     memory_region_add_subregion(&s->sdram, 0, &a->scu->dram_remap_alias[2]);\n \n+    /* SCUIO */\n+    memory_region_init_alias(&a->scuio_alias, OBJECT(a), \"scuio.alias\",\n+                             &a->scuio->iomem, 0,\n+                             memory_region_size(&a->scuio->iomem));\n+    memory_region_add_subregion(s->memory, sc->memmap[ASPEED_DEV_SCUIO],\n+                                &a->scuio_alias);\n+\n     /* INTC */\n     if (!sysbus_realize(SYS_BUS_DEVICE(&a->intc[0]), errp)) {\n         return;\n@@ -279,9 +284,6 @@ static void aspeed_soc_ast27x0tsp_realize(DeviceState *dev_soc, Error **errp)\n     aspeed_mmio_map_unimplemented(s->memory, SYS_BUS_DEVICE(&a->ipc[1]),\n                                   \"aspeed.ipc1\",\n                                   sc->memmap[ASPEED_DEV_IPC1], 0x1000);\n-    aspeed_mmio_map_unimplemented(s->memory, SYS_BUS_DEVICE(&a->scuio),\n-                                  \"aspeed.scuio\",\n-                                  sc->memmap[ASPEED_DEV_SCUIO], 0x1000);\n     aspeed_mmio_map_unimplemented(s->memory, SYS_BUS_DEVICE(&a->pric[0]),\n                                   \"aspeed.pric0\",\n                                   sc->memmap[ASPEED_DEV_PRIC0], 0x1000);\n@@ -296,6 +298,8 @@ static void aspeed_soc_ast27x0tsp_realize(DeviceState *dev_soc, Error **errp)\n static const Property aspeed_27x0_coprocessor_properties[] = {\n     DEFINE_PROP_LINK(\"scu\", Aspeed27x0CoprocessorState, scu,\n                      TYPE_ASPEED_2700_SCU, Aspeed2700SCUState *),\n+    DEFINE_PROP_LINK(\"scuio\", Aspeed27x0CoprocessorState, scuio,\n+                     TYPE_ASPEED_SCU, AspeedSCUState *),\n     DEFINE_PROP_LINK(\"fmc\", Aspeed27x0CoprocessorState, fmc, TYPE_ASPEED_SMC,\n                      AspeedSMCState *),\n };\n",
    "prefixes": [
        "v4",
        "18/21"
    ]
}