get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 2224194,
    "url": "http://patchwork.ozlabs.org/api/1.2/patches/2224194/?format=api",
    "web_url": "http://patchwork.ozlabs.org/project/qemu-devel/patch/20260417032837.2664122-6-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-6-jamin_lin@aspeedtech.com>",
    "list_archive_url": null,
    "date": "2026-04-17T03:28:45",
    "name": "[v4,05/21] hw/arm/ast27x0: Add DRAM alias for SSP SDRAM remap",
    "commit_ref": null,
    "pull_url": null,
    "state": "new",
    "archived": false,
    "hash": "b9a5657a01c0f24deef565e62b173df9f0e353c5",
    "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-6-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/2224194/comments/",
    "check": "pending",
    "checks": "http://patchwork.ozlabs.org/api/patches/2224194/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=GTn4RbwD;\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 4fxgR31MRYz1yD3\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 17 Apr 2026 13:31: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 1wDZt6-0002F2-IE; Thu, 16 Apr 2026 23:29:00 -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 1wDZt4-0002E7-RI; Thu, 16 Apr 2026 23:28:58 -0400",
            "from mail-japaneastazlp170120005.outbound.protection.outlook.com\n ([2a01:111:f403:c405::5] helo=TYPPR03CU001.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 1wDZt3-0005oG-4j; Thu, 16 Apr 2026 23:28:58 -0400",
            "from TYPPR06MB8206.apcprd06.prod.outlook.com (2603:1096:405:383::19)\n by KL1PR06MB6299.apcprd06.prod.outlook.com (2603:1096:820:ce::14)\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:28:46 +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:28:46 +0000"
        ],
        "ARC-Seal": "i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none;\n b=Bd1aF8EOuN6+RbH69TYubyar3wlU4CLZ064Z6OshWP1lRj3OVhp3peiL/tcPzZsx4oR30v/0yUwDt0lXEZUscWGdpD0k+sZkr9sJkPt8/rNa7l7G4uWIa+uPlu8tsyq+uonBrghMsF/s7ORAsi7o8aCIHmITzm7YC4rL/BZi96Tbl5DSpJjxwSHsH38/nsLcvdm2dprozlVDUMbHwcqr8EBMPItGbCo0GPqoL3ru4oy450HUieHrSvkVW7M+F7c+1nFyD4NG7ItY4hrFUEc8ldzdKhzkHXC7bHDmmrh3iV+OXI2v4NWmMhRfz+MVrYejmte/+G6yT5z5xYtzDiSK6g==",
        "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=0e+xjd7ySC59jWZIeY6oWCYA1XZY84Kbg7cGwbgv0wY=;\n b=zJkXpFGmKsXFRS4N9N0CbOr3SkfJ2kQnoz4fVAZOywhzpopjddwdkwqSlMsOJBaFROM2DmXdy3+CkcZD7rYpee6fbN6nN+HfJ25DzVDavet5kAbbNac8a+WtGtJGxB7B1REXWRpJepSqn/w9TffWwnNBHftE6O+YLR2wack3D5vwgTNQWvFA6rNaPUAq7L3jCWPbVyXIi8F/Tsrbt9cCiZFOYfFX4+9RYTPJ2dOsfYwZWHItk6CIcNCSUiOhamVt/JzFbgA2FAILnuDHF4MO1GQUxWa/tBHJXHqjbFGdMtddm8+TlSDxRbgNGMsBupHJPvDIFfXHTgB4aQKg9Nkzdg==",
        "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=0e+xjd7ySC59jWZIeY6oWCYA1XZY84Kbg7cGwbgv0wY=;\n b=GTn4RbwDAW3KHh+0lX8FCIbXLYaMG+iaFAFnPW6FuIXEQNcUGACBkyjheN9+ZgFtshn8ROktNrMMthuoU2cdsYX1AgvkiRk2dA8VedL+LtGTWzL6sD4ProIrLWzU6YpDoorXa2fOHxyx1OkPaVFnao6n3hhXlQxZJfFck3+7+iO/ALnqBtz78hUOj/AAjBGDrMYrvRsywm54gJpmySgGepJFEp8aPZX3IkXehY07bRaof8/wPZ6Qh04KkDe1j0ckHi9vOWvX1ZRLbaRNt8XYpDwpx5mjBxYzcHwp3AwxtiTYzB/FlxdOKUo9DLBcJupft5VlzT5KoiQAzAiIBF8XTw==",
        "From": "Jamin Lin <jamin_lin@aspeedtech.com>",
        "To": "=?iso-8859-1?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 05/21] hw/arm/ast27x0: Add DRAM alias for SSP SDRAM remap",
        "Thread-Topic": "[PATCH v4 05/21] hw/arm/ast27x0: Add DRAM alias for SSP SDRAM\n remap",
        "Thread-Index": "AQHczhpMih2bvP+gF0eQLYKwHPAx6Q==",
        "Date": "Fri, 17 Apr 2026 03:28:45 +0000",
        "Message-ID": "<20260417032837.2664122-6-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=GTn4RbwD;\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_|KL1PR06MB6299:EE_",
        "x-ms-office365-filtering-correlation-id": "eb3814d3-bf28-4755-3fc9-08de9c316eeb",
        "x-ms-exchange-senderadcheck": "1",
        "x-ms-exchange-antispam-relay": "0",
        "x-microsoft-antispam": "BCL:0;\n ARA:13230040|1800799024|376014|7416014|366016|921020|38070700021|56012099003|18002099003|22082099003;",
        "x-microsoft-antispam-message-info": "\n UYNJTYbpiFzStUlwQCpQju57lxQDaysO2Gsg978ZJ/vtn5s6Wp7keAxIYN/8ukUXiyNBXoLAd8Sh2JYNS05juD8KuzClKLrF7DlhVECePVtrb9DWgtuRN/vTY9CRLdiJLKQlN3Qxv/EN5L5GAQn5HfXpFGDAFmOzpEz1VaBXH3Crtu2OLgSj+hnDwrm/RR7bXjYehQHsRhs1Pl8LspOXmP0MqrsYGx4Brvmzir5d+4kK9See7FKj7gbkDXIpgEk6TYXcU4Gg7r+5i2/IUkPgQ1OpXGf1fFhftti/HjWYTC6NVjz3IeoJegdutaK/cdIXvUVsqNRhpY3nWbKy0gYFrTKTQSFdh/hyczA8o2FriyN1BSAR0Ik7Zfsqo+ScldVMiN9chfVsWQdQXzb7uGwULFr1delWtczRDP9F5ARKKyjUJ4soVn8XRWW8REET0R4iDw8OYEzqiynzB1gcZGKbco9EeZZZU2k+q1TxRbNEQhv9vNxSqbKmEW5nlqURFwlXI7N087plH4qG8WUAmuE5iuOij9l2rQlNIUea8UFY41nk/lFrutUl6mV4xUjMk887U3H3qHSZ3lBe7j3ytTqI78GyzXfU1HSTCIv3tYjTEnuv8R0dyjFMuIgYwtPRbF2j4zI6JKKjR/19ro2G3Esf0xGC+6bVxDCJuUaVLEGgu8Gb0ZbsHPCi+AhspG7NJhMw/cbWAOLF0alUOXyMM1Ij6yVmEGrhbzXX1RNaBgspyJKL1DIOG0pnv2NOS9VTNiz68snAYLB55cjfwKj3nAru4E+7bd2k+eUU/+V91QPjdS99xPJxAP2q/ZVgCHL3JqTY",
        "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)(376014)(7416014)(366016)(921020)(38070700021)(56012099003)(18002099003)(22082099003);\n DIR:OUT; SFP:1102;",
        "x-ms-exchange-antispam-messagedata-chunkcount": "1",
        "x-ms-exchange-antispam-messagedata-0": "=?iso-8859-1?q?30Z101IyaDLIoZZ6T+1k3G3?=\n\t=?iso-8859-1?q?+FWoGmgFYKS1wtUc3kO7CniA05XE58d9LbmPYVsg7plbd+F+mrHMM+XNeAXq?=\n\t=?iso-8859-1?q?lU+q4ak/0lwZXDUNrYmPqw0foegrgyKmbETWbxqYmLdfdXNlvDujCev14Fur?=\n\t=?iso-8859-1?q?4bTW++vAmsM7K9Vx3WI3idyVGuZ0BUv027kbYxTofjTPrtTe5rOVSNSv2Ngg?=\n\t=?iso-8859-1?q?VQykwuPyb4ayjuT+MMt9vRNRFzTCLQf7ANnxPyyh1M+TxwDY5CyO40F5bfeS?=\n\t=?iso-8859-1?q?PaaVfV+FKOCVTHTlegGfnX0GFh4C3vhfu5NUN8Se6KdtWipFN6C4Wqg0tGSn?=\n\t=?iso-8859-1?q?aucjmzb6Wn2HilfndutycwTUT+yQe+s1jIjS13mbVLb3+/zzW/syLLV5I3BG?=\n\t=?iso-8859-1?q?FB9r1OpHjP9wKnSEHs5noZEZ5UhM4T14dK9GswPZPOwxTy3XlMwqZFiDICDj?=\n\t=?iso-8859-1?q?3f1ldTw7QCWbEHgQoA8JEejM3CcC8+eg0nkcoPS22FTOSzv0LNEWMMzbsJLD?=\n\t=?iso-8859-1?q?WXvlyrvAutRAcfzAXacFYzYUG6UJOM2qQePg2DEH7QvzqH8HV46p3i9nI1y3?=\n\t=?iso-8859-1?q?4zutsjda67Be+xHZjGUMSsovVMcTUdmekvfyRpqmXxdTYD91Jm28VWq86ZJ+?=\n\t=?iso-8859-1?q?ZVgVl+T5Y5nWEWKIhbDP3lt63gzpuctP9I4NFlM5Xv1DXAh6+ceTftKonBjc?=\n\t=?iso-8859-1?q?iAGGpaekgLSMwomM2v2FRAcLcdJUXVcfiAiJ6xiNaWPbiv0CxQAChgposGEK?=\n\t=?iso-8859-1?q?Lw4qoSSQ0jewTrNhmVjt081GOnKV9gYouYYDSpy/4bphgaG4V39eWU52KH1c?=\n\t=?iso-8859-1?q?A5+6TaxAB2/Mw1oDFb7jSTJKZxLFmksHe0iw/toG0kDvTsYL677a0Sjmd8bS?=\n\t=?iso-8859-1?q?oqOKrw5yN72ukXZ/xrUH+/dysKdenewzMVTj50GWR6UQ/qy00ya2/S+3YSpn?=\n\t=?iso-8859-1?q?VCs9pJU8EUT9MLASn57zU8cJhYmLmyISGkWmY8lWzoBbFAJkmhUL7fhPqte9?=\n\t=?iso-8859-1?q?0M2AOZKI4o8VcC2V55eRrQQn5ZvbT6oKPGsU7Btsyg4olCLquXVt/upMmSyt?=\n\t=?iso-8859-1?q?s3B/PqpWcQFmqetS+WbVefwtmw2VxNAE4Hb+EOhONNDQLGWmqcWYZy8fanXa?=\n\t=?iso-8859-1?q?ajYJmQPq8TdKfPh2MP00G2TfHtg/dbubPIDaUmRybYFcSO3l5miNqjUMzLPU?=\n\t=?iso-8859-1?q?G8Hs8rDPIsqMRw0WE4yNJSTm+0TRHAfLE3iG/W657X/PQ5CKYntTh+TWClGH?=\n\t=?iso-8859-1?q?ZXt3TFwk9nMl63a6w5Vh7C1Ojrzic9o2GJ+0w+z76e0u9Sj7QBiifdpSs7pY?=\n\t=?iso-8859-1?q?wV6AygvX4ryeJ9aV345xE0sBVDurpyzkEEOn5Sr6P6bEOS9o5PuFn+4vDhFX?=\n\t=?iso-8859-1?q?P2PffBUfLAUr0FHFx6lyMx2s36WJy7pzPrDIKRIjx1z7ijdDjyuOzhh97px9?=\n\t=?iso-8859-1?q?O/gfLLle5M2Com0cuFhQur6WnKGTAN72uenoV5NRX2MVSCVBet0zFC03++DP?=\n\t=?iso-8859-1?q?EQ/QnqI8r8YWCk7LLW8WwmQWMxTtWmwUOM5Ibn8ARE3/NtUsg6q1XvlDkQLF?=\n\t=?iso-8859-1?q?PX8XO3SnI6v7Lb/5TeiaYq12vEMLK/iE7NHgvvS9rgVZ3s/tlcVJswCPVknl?=\n\t=?iso-8859-1?q?hCw8PIZejdKsofHHi2yxLu9Y0Ql9/icshO3ndNl5OCQmT4H5zl7ol8sEWgN3?=\n\t=?iso-8859-1?q?o+THvY2HsAVMPimfbe6nuAUFla5vtA2zoZnlcjqzWlsAG8e48dYJZhuUPbNg?=\n\t=?iso-8859-1?q?ys7afrdfbRfr2WmVfX1duofkB6oK5BD4CS1xPu35XtSmPGQ=3D=3D?=",
        "Content-Type": "text/plain; charset=\"iso-8859-1\"",
        "Content-Transfer-Encoding": "quoted-printable",
        "MIME-Version": "1.0",
        "X-Exchange-RoutingPolicyChecked": "\n v9d2MbQWDUp3FE+6xxpu6CAF9jj77nxxg8ZJxeWWjnr6P66TqOJVEQ/px3wp0hZ3ugMFjDmjk+s4zD+BTm2lUJvx5RzO3QytsmEfTFLit3rfsdvS37/pxPvEDoXGv2zG9MBSwhVLps9BJXrP8eMpi5SfF1/Ovez2ZJhQB1HUGj+3ZycfpBauKiEnXkV/GBGHAu18X1opugWQl/G22IKUQLYA/stOUpruaXM8Fg6ZBza1g6qPMwvuw8TvCPujsUpLGsByIrmYmINEvvpCzYr+xPRIOiWcuB379p37MjwCwBbfY1rqML7r3ykrBM+K411qhvKOc26QvLdH7XZUNLrOJA==",
        "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 eb3814d3-bf28-4755-3fc9-08de9c316eeb",
        "X-MS-Exchange-CrossTenant-originalarrivaltime": "17 Apr 2026 03:28:45.5171 (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 mgjOqJ2iyBIW1bsJc9NHaXg+xKmgrham+ZqrkclXiB3hM1kUQtgnkSZ0deRy4uvraU3zMYPM/C4yjCnAPydEk49tiDAT6szrkWJYW3u0L6s=",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "KL1PR06MB6299",
        "Received-SPF": "pass client-ip=2a01:111:f403:c405::5;\n envelope-from=jamin_lin@aspeedtech.com;\n helo=TYPPR03CU001.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": "This commit adds two MemoryRegion aliases to support PSP access to\nSSP SDRAM through shared memory remapping.\n\nThe SSP exposes two DRAM aliases:\n  - remap1 maps PSP DRAM at 0x400000000 to SSP SDRAM offset 0x5880000\n  - remap2 maps PSP DRAM at 0x42C000000 to SSP SDRAM offset 0x0\n\nThese mappings follow the default SCU register configuration used by\nthe ASPEED SDK firmware, which defines the memory window mapping\nbetween PSP and the SSP.\n\nSet SSP CPUID 4.\n\nSigned-off-by: Jamin Lin <jamin_lin@aspeedtech.com>\n---\n include/hw/misc/aspeed_scu.h |  4 ++++\n hw/arm/aspeed_ast27x0-fc.c   |  2 ++\n hw/arm/aspeed_ast27x0-ssp.c  |  6 ++++++\n hw/arm/aspeed_ast27x0.c      |  4 ++++\n hw/misc/aspeed_scu.c         | 36 ++++++++++++++++++++++++++++++++++++\n 5 files changed, 52 insertions(+)",
    "diff": "diff --git a/include/hw/misc/aspeed_scu.h b/include/hw/misc/aspeed_scu.h\nindex fd30313e69..106ab4b04a 100644\n--- a/include/hw/misc/aspeed_scu.h\n+++ b/include/hw/misc/aspeed_scu.h\n@@ -44,6 +44,10 @@ struct AspeedSCUState {\n \n struct Aspeed2700SCUState {\n     AspeedSCUState parent_obj;\n+\n+    MemoryRegion dram_remap_alias[3];\n+    MemoryRegion *dram;\n+    int ssp_cpuid;\n };\n \n #define AST2400_A1_SILICON_REV   0x02010303U\ndiff --git a/hw/arm/aspeed_ast27x0-fc.c b/hw/arm/aspeed_ast27x0-fc.c\nindex 46f0c97329..0688750e78 100644\n--- a/hw/arm/aspeed_ast27x0-fc.c\n+++ b/hw/arm/aspeed_ast27x0-fc.c\n@@ -100,6 +100,8 @@ static bool ast2700fc_ca35_init(MachineState *machine, Error **errp)\n                             sc->uarts_num, serial_hd(1));\n     aspeed_soc_uart_set_chr(soc->uart, ASPEED_DEV_UART7, sc->uarts_base,\n                             sc->uarts_num, serial_hd(2));\n+    object_property_set_int(OBJECT(&s->ca35), \"ssp-cpuid\", 4,\n+                            &error_abort);\n     if (!qdev_realize(DEVICE(&s->ca35), NULL, errp)) {\n         return false;\n     }\ndiff --git a/hw/arm/aspeed_ast27x0-ssp.c b/hw/arm/aspeed_ast27x0-ssp.c\nindex edfcf1badb..0500c02755 100644\n--- a/hw/arm/aspeed_ast27x0-ssp.c\n+++ b/hw/arm/aspeed_ast27x0-ssp.c\n@@ -199,6 +199,12 @@ static void aspeed_soc_ast27x0ssp_realize(DeviceState *dev_soc, Error **errp)\n     memory_region_add_subregion(s->memory, sc->memmap[ASPEED_DEV_SCU],\n                                 &a->scu_alias);\n \n+    /* SDRAM remap alias used by PSP to access SSP SDRAM */\n+    memory_region_add_subregion(&s->sdram, 0, &a->scu->dram_remap_alias[1]);\n+    memory_region_add_subregion(&s->sdram,\n+            memory_region_size(&a->scu->dram_remap_alias[1]),\n+            &a->scu->dram_remap_alias[0]);\n+\n     /* INTC */\n     if (!sysbus_realize(SYS_BUS_DEVICE(&a->intc[0]), errp)) {\n         return;\ndiff --git a/hw/arm/aspeed_ast27x0.c b/hw/arm/aspeed_ast27x0.c\nindex e84975a9c4..e38b829cc7 100644\n--- a/hw/arm/aspeed_ast27x0.c\n+++ b/hw/arm/aspeed_ast27x0.c\n@@ -432,6 +432,8 @@ static void aspeed_soc_ast2700_init(Object *obj)\n                               \"hw-strap1\");\n     object_property_add_alias(obj, \"hw-prot-key\", OBJECT(&a->scu),\n                               \"hw-prot-key\");\n+    object_property_add_alias(obj, \"ssp-cpuid\", OBJECT(&a->scu),\n+                              \"ssp-cpuid\");\n \n     object_initialize_child(obj, \"scuio\", &s->scuio, TYPE_ASPEED_2700_SCUIO);\n     qdev_prop_set_uint32(DEVICE(&s->scuio), \"silicon-rev\",\n@@ -794,6 +796,8 @@ static void aspeed_soc_ast2700_realize(DeviceState *dev, Error **errp)\n                                 sc->memmap[ASPEED_DEV_VBOOTROM], &s->vbootrom);\n \n     /* SCU */\n+    object_property_set_link(OBJECT(&a->scu), \"dram\", OBJECT(s->dram_mr),\n+                             &error_abort);\n     if (!sysbus_realize(SYS_BUS_DEVICE(&a->scu), errp)) {\n         return;\n     }\ndiff --git a/hw/misc/aspeed_scu.c b/hw/misc/aspeed_scu.c\nindex 51696443bd..7080bd6241 100644\n--- a/hw/misc/aspeed_scu.c\n+++ b/hw/misc/aspeed_scu.c\n@@ -20,6 +20,7 @@\n #include \"qemu/guest-random.h\"\n #include \"qemu/module.h\"\n #include \"trace.h\"\n+#include \"qemu/units.h\"\n \n #define TO_REG(offset) ((offset) >> 2)\n \n@@ -961,9 +962,42 @@ static void aspeed_ast2700_scu_reset(DeviceState *dev)\n \n static void aspeed_2700_scu_realize(DeviceState *dev, Error **errp)\n {\n+    Aspeed2700SCUState *a = ASPEED_2700_SCU(dev);\n+\n     aspeed_scu_realize(dev, errp);\n+\n+    if (a->ssp_cpuid > 0) {\n+        if (!a->dram) {\n+            error_setg(errp, TYPE_ASPEED_2700_SCU \": 'dram' link not set\");\n+            return;\n+        }\n+    }\n+\n+    if (a->ssp_cpuid > 0) {\n+        /*\n+         * The SSP coprocessor uses two memory aliases (remap1 and remap2)\n+         * to access shared memory regions in the PSP DRAM:\n+         *\n+         * - remap1 maps PSP DRAM at 0x400000000 (size: 0x1A77E000) to\n+         *   SSP SDRAM offset 0x5880000\n+         * - remap2 maps PSP DRAM at 0x42C000000 (size: 0x05880000) to\n+         *   SSP SDRAM offset 0x0\n+         */\n+        memory_region_init_alias(&a->dram_remap_alias[0], OBJECT(a),\n+                                 \"ssp.dram.remap1\", a->dram,\n+                                 0, 0x1a77e000);\n+        memory_region_init_alias(&a->dram_remap_alias[1], OBJECT(a),\n+                                 \"ssp.dram.remap2\", a->dram,\n+                                 0x2c000000, 0x05880000);\n+    }\n }\n \n+static const Property aspeed_2700_scu_properties[] = {\n+    DEFINE_PROP_INT32(\"ssp-cpuid\", Aspeed2700SCUState, ssp_cpuid, -1),\n+    DEFINE_PROP_LINK(\"dram\", Aspeed2700SCUState, dram, TYPE_MEMORY_REGION,\n+                     MemoryRegion *),\n+};\n+\n static void aspeed_2700_scu_class_init(ObjectClass *klass, const void *data)\n {\n     DeviceClass *dc = DEVICE_CLASS(klass);\n@@ -972,6 +1006,8 @@ static void aspeed_2700_scu_class_init(ObjectClass *klass, const void *data)\n     dc->desc = \"ASPEED 2700 System Control Unit\";\n     device_class_set_legacy_reset(dc, aspeed_ast2700_scu_reset);\n     dc->realize = aspeed_2700_scu_realize;\n+    device_class_set_props(dc, aspeed_2700_scu_properties);\n+\n     asc->resets = ast2700_a0_resets;\n     asc->calc_hpll = aspeed_2600_scu_calc_hpll;\n     asc->get_apb = aspeed_2700_scu_get_apb_freq;\n",
    "prefixes": [
        "v4",
        "05/21"
    ]
}