get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 2195123,
    "url": "http://patchwork.ozlabs.org/api/patches/2195123/?format=api",
    "web_url": "http://patchwork.ozlabs.org/project/qemu-ppc/patch/20260210134110.1515322-4-saif.abrar@linux.vnet.ibm.com/",
    "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": "<20260210134110.1515322-4-saif.abrar@linux.vnet.ibm.com>",
    "list_archive_url": null,
    "date": "2026-02-10T13:40:53",
    "name": "[v3,3/9] pnv/phb4: Implement sticky reset logic in PHB4",
    "commit_ref": null,
    "pull_url": null,
    "state": "new",
    "archived": false,
    "hash": "9eab933b16fa0d3272835e1bcd4fd5b0caa8d6d6",
    "submitter": {
        "id": 87200,
        "url": "http://patchwork.ozlabs.org/api/people/87200/?format=api",
        "name": "Saif Abrar",
        "email": "saif.abrar@linux.vnet.ibm.com"
    },
    "delegate": null,
    "mbox": "http://patchwork.ozlabs.org/project/qemu-ppc/patch/20260210134110.1515322-4-saif.abrar@linux.vnet.ibm.com/mbox/",
    "series": [
        {
            "id": 491676,
            "url": "http://patchwork.ozlabs.org/api/series/491676/?format=api",
            "web_url": "http://patchwork.ozlabs.org/project/qemu-ppc/list/?series=491676",
            "date": "2026-02-10T13:40:52",
            "name": "[v3,1/9] qtest/phb4: Add testbench for PHB4",
            "version": 3,
            "mbox": "http://patchwork.ozlabs.org/series/491676/mbox/"
        }
    ],
    "comments": "http://patchwork.ozlabs.org/api/patches/2195123/comments/",
    "check": "pending",
    "checks": "http://patchwork.ozlabs.org/api/patches/2195123/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=ibm.com header.i=@ibm.com header.a=rsa-sha256\n header.s=pp1 header.b=eGdhf3sG;\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 4f9N6D0WLrz1xvb\n\tfor <incoming@patchwork.ozlabs.org>; Wed, 11 Feb 2026 00:42:28 +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 1vpo0F-0001Hi-FP; Tue, 10 Feb 2026 08:42:07 -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 <saif.abrar@linux.vnet.ibm.com>)\n id 1vpo0D-0001FY-Db; Tue, 10 Feb 2026 08:42:05 -0500",
            "from mx0b-001b2d01.pphosted.com ([148.163.158.5])\n by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)\n (Exim 4.90_1) (envelope-from <saif.abrar@linux.vnet.ibm.com>)\n id 1vpo0B-00039O-Ao; Tue, 10 Feb 2026 08:42:05 -0500",
            "from pps.filterd (m0356516.ppops.net [127.0.0.1])\n by mx0a-001b2d01.pphosted.com (8.18.1.11/8.18.1.11) with ESMTP id\n 61A21Na83344155; Tue, 10 Feb 2026 13:41:55 GMT",
            "from ppma23.wdc07v.mail.ibm.com\n (5d.69.3da9.ip4.static.sl-reverse.com [169.61.105.93])\n by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 4c696utawj-1\n (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT);\n Tue, 10 Feb 2026 13:41:54 +0000 (GMT)",
            "from pps.filterd (ppma23.wdc07v.mail.ibm.com [127.0.0.1])\n by ppma23.wdc07v.mail.ibm.com (8.18.1.2/8.18.1.2) with ESMTP id\n 61AAJ9wv012996;\n Tue, 10 Feb 2026 13:41:53 GMT",
            "from smtprelay02.dal12v.mail.ibm.com ([172.16.1.4])\n by ppma23.wdc07v.mail.ibm.com (PPS) with ESMTPS id 4c6h7k9cfw-1\n (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT);\n Tue, 10 Feb 2026 13:41:53 +0000",
            "from smtpav03.wdc07v.mail.ibm.com (smtpav03.wdc07v.mail.ibm.com\n [10.39.53.230])\n by smtprelay02.dal12v.mail.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id\n 61ADfqpd32637572\n (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK);\n Tue, 10 Feb 2026 13:41:52 GMT",
            "from smtpav03.wdc07v.mail.ibm.com (unknown [127.0.0.1])\n by IMSVA (Postfix) with ESMTP id 278C758054;\n Tue, 10 Feb 2026 13:41:52 +0000 (GMT)",
            "from smtpav03.wdc07v.mail.ibm.com (unknown [127.0.0.1])\n by IMSVA (Postfix) with ESMTP id EF7FD58062;\n Tue, 10 Feb 2026 13:41:50 +0000 (GMT)",
            "from gfwr526.rchland.ibm.com (unknown [9.10.239.119])\n by smtpav03.wdc07v.mail.ibm.com (Postfix) with ESMTP;\n Tue, 10 Feb 2026 13:41:50 +0000 (GMT)"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=cc\n :content-transfer-encoding:date:from:in-reply-to:message-id\n :mime-version:references:subject:to; s=pp1; bh=/Ee/vrBuisPb5FR9L\n Yrg0J7JmfDlhDn6A5vLX5uLFas=; b=eGdhf3sG4dvsRYcUqfo0GLCa/MZR0HHgV\n z4YpI5l8px7Moh2yg9qof0ykz63BgdLBjs6HZ3GvLaFd79O2XUlPY8HXo6GAJMiI\n XTZynL1+ojkvCl4Kx1pLKnk7r4NsdpTf2jf7ioDkAmKKHPs6d2pifXpe8H7W3LLf\n L4FsWOHzFbRxNdnUncwXYoHB9JWGS/lZbFy6DkTwxP+2iuyhzUs6gh56JM1HV8HX\n qVmD4JWgOj11vvs5I4ZWGKz2KAGaf20qoqWtx1R0a+FJSwPJAOIX6mIgOov5UDDK\n Q2IOCaMQ9nrt5xOPkGe1FhPu1LGVqN5+WNklZvs/FC9qG3i12X3QQ==",
        "From": "Saif Abrar <saif.abrar@linux.vnet.ibm.com>",
        "To": "qemu-ppc@nongnu.org, qemu-devel@nongnu.org",
        "Cc": "clg@kaod.org, npiggin@gmail.com, fbarrat@linux.ibm.com, mst@redhat.com,\n marcel.apfelbaum@gmail.com, cohuck@redhat.com, pbonzini@redhat.com,\n thuth@redhat.com, lvivier@redhat.com, danielhb413@gmail.com,\n saif.abrar@linux.vnet.ibm.com",
        "Subject": "[PATCH v3 3/9] pnv/phb4: Implement sticky reset logic in PHB4",
        "Date": "Tue, 10 Feb 2026 07:40:53 -0600",
        "Message-ID": "<20260210134110.1515322-4-saif.abrar@linux.vnet.ibm.com>",
        "X-Mailer": "git-send-email 2.47.3",
        "In-Reply-To": "<20260210134110.1515322-1-saif.abrar@linux.vnet.ibm.com>",
        "References": "<20251230102156.886288-1-saif.abrar@linux.vnet.ibm.com>\n <20260210134110.1515322-1-saif.abrar@linux.vnet.ibm.com>",
        "MIME-Version": "1.0",
        "Content-Transfer-Encoding": "8bit",
        "X-TM-AS-GCONF": "00",
        "X-Proofpoint-Reinject": "loops=2 maxloops=12",
        "X-Proofpoint-Spam-Details-Enc": "AW1haW4tMjYwMjEwMDExMiBTYWx0ZWRfX+sZlEoQOnRe8\n Ub+Q0tBqO51xEKTbSD5bEqOHFjXH9mFgOp/LAdl61mYd41Rsm1ZhYBHPRKNZh7A/vX/PyloZBlm\n xr3o1iaV5J+ime+uwpOIMKGEcIoKsuFAC/7ZLMHOsvL5iLU1svhyjaYA3D+gzU8ke6Sn8MeG8nA\n WhSa6L+R9yD5jBSS7WL7ZZ9tGhhCg2xuz3Jjvowf0ZTY30ShFO4+RqEuhNxsScYBUjF/nZiYJw/\n N9zmd6SIlHkpJzBAozPHyQ4TJAn3P6Y0MGyWYm4j7p8K4Q82vbK0Nadg/vVSRd1GXojgCgQXOap\n UY22PnKCkH6FpAtwIVVfED9oz0cYsugxWSer/KSm+AzOA/qVnDJ02sBOPHSthjnK1H20H0kN/2Q\n O0nmrInWaITKSyyKhJYegCmIVtvdmy6fzkk7qEEk6SqrTlJfxM2rMegf2u2Y3pG1dUB87ZwIb7s\n 2Mx7Nt6ciCebF2GIJ5g==",
        "X-Proofpoint-ORIG-GUID": "y8DoU46VTy3etPWU1Kht1E7YvNy2yfE5",
        "X-Proofpoint-GUID": "jMy2L0uF6YfHq7Q6j28SDQdBOsr-PIDl",
        "X-Authority-Analysis": "v=2.4 cv=O+Y0fR9W c=1 sm=1 tr=0 ts=698b35a2 cx=c_pps\n a=3Bg1Hr4SwmMryq2xdFQyZA==:117 a=3Bg1Hr4SwmMryq2xdFQyZA==:17\n a=HzLeVaNsDn8A:10 a=VkNPw1HP01LnGYTKEx00:22 a=Mpw57Om8IfrbqaoTuvik:22\n a=GgsMoib0sEa3-_RKJdDe:22 a=VnNF1IyMAAAA:8 a=cXRGBLWJx9Q7mz3AcBIA:9",
        "X-Proofpoint-Virus-Version": "vendor=baseguard\n engine=ICAP:2.0.293,Aquarius:18.0.1121,Hydra:6.1.51,FMLib:17.12.100.49\n definitions=2026-02-10_01,2026-02-10_02,2025-10-01_01",
        "X-Proofpoint-Spam-Details": "rule=outbound_notspam policy=outbound score=0\n lowpriorityscore=0 priorityscore=1501 phishscore=0 adultscore=0\n malwarescore=0 impostorscore=0 bulkscore=0 clxscore=1015 spamscore=0\n suspectscore=0 classifier=typeunknown authscore=0 authtc= authcc=\n route=outbound adjust=0 reason=mlx scancount=1 engine=8.22.0-2601150000\n definitions=main-2602100112",
        "Received-SPF": "none client-ip=148.163.158.5;\n envelope-from=saif.abrar@linux.vnet.ibm.com; helo=mx0b-001b2d01.pphosted.com",
        "X-Spam_score_int": "-19",
        "X-Spam_score": "-2.0",
        "X-Spam_bar": "--",
        "X-Spam_report": "(-2.0 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1,\n DKIM_VALID=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_DNSWL_NONE=-0.0001,\n RCVD_IN_MSPIKE_H4=0.001, RCVD_IN_MSPIKE_WL=0.001,\n RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, RCVD_IN_VALIDITY_SAFE_BLOCKED=0.001,\n SPF_HELO_NONE=0.001, SPF_NONE=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": "Sticky bits retain their values on reset and are not overwritten with\nthe reset value.\nAdded sticky reset logic for all required registers,\ni.e. CFG core, PBL core, PHB error registers, PCIE stack registers and\nREGB error registers.\n\nTested by writing all 1's to the reg PHB_PBL_ERR_INJECT.\nThis will set the bits in the reg PHB_PBL_ERR_STATUS.\nReset the PBL core by setting PHB_PCIE_CRESET_PBL in reg PHB_PCIE_CRESET.\nVerify that the sticky bits in the PHB_PBL_ERR_STATUS reg are still set.\n\nSigned-off-by: Saif Abrar <saif.abrar@linux.vnet.ibm.com>\n---\nv3: Updates for coding guidelines.\n\n\n hw/pci-host/pnv_phb4.c              | 125 +++++++++++++++++++++++++++-\n include/hw/pci-host/pnv_phb4_regs.h |  20 ++++-\n tests/qtest/pnv-phb4-test.c         |  41 +++++++++\n 3 files changed, 180 insertions(+), 6 deletions(-)",
    "diff": "diff --git a/hw/pci-host/pnv_phb4.c b/hw/pci-host/pnv_phb4.c\nindex 8334ffe42f..961888e952 100644\n--- a/hw/pci-host/pnv_phb4.c\n+++ b/hw/pci-host/pnv_phb4.c\n@@ -510,9 +510,22 @@ static uint32_t get_exp_offset(PCIDevice *pdev)\n     return rpc->exp_offset;\n }\n \n+/*\n+ * Apply sticky-mask 's' to the reset-value 'v' and write to the address 'a'.\n+ * RC-config space values and masks are LE.\n+ * Method pnv_phb4_rc_config_read() returns BE, hence convert to LE.\n+ * Compute new value in LE domain.\n+ * New value computation using sticky-mask is in LE.\n+ * Convert the computed value from LE to BE before writing back.\n+ */\n+#define RC_CONFIG_STICKY_RESET(a, v, s) \\\n+    (pci_set_word(conf + (a), bswap32( \\\n+                     (bswap32(pci_get_word(conf + (a))) & (s)) | ((v) & ~(s)))))\n+\n void pnv_phb4_cfg_core_reset(PCIDevice *d)\n {\n     uint8_t *conf = d->config;\n+    uint32_t exp_offset = get_exp_offset(d);\n \n     pci_set_word(conf + PCI_COMMAND, PCI_COMMAND_SERR);\n     pci_set_word(conf + PCI_STATUS, PCI_STATUS_CAP_LIST);\n@@ -526,7 +539,6 @@ void pnv_phb4_cfg_core_reset(PCIDevice *d)\n     pci_set_word(conf + PCI_BRIDGE_CONTROL, PCI_BRIDGE_CTL_SERR);\n     pci_set_long(conf + PCI_BRIDGE_CONTROL + PCI_PM_PMC, 0xC8034801);\n \n-    uint32_t exp_offset = get_exp_offset(d);\n     pci_set_long(conf + exp_offset, 0x420010);\n     pci_set_long(conf + exp_offset + PCI_EXP_DEVCAP,  0x8022);\n     pci_set_long(conf + exp_offset + PCI_EXP_DEVCTL, PCI_EXP_DEVCTL_EXT_TAG\n@@ -559,14 +571,56 @@ void pnv_phb4_cfg_core_reset(PCIDevice *d)\n     pci_set_long(conf + P16_ECAP, 0x22410026);\n     pci_set_long(conf + P32_ECAP, 0x1002A);\n     pci_set_long(conf + P32_CAP,  0x103);\n+\n+    /* Sticky reset */\n+    RC_CONFIG_STICKY_RESET(exp_offset + PCI_EXP_LNKCTL2,\n+                                          PCI_EXP_LNKCTL2_TLS_32_0GT, 0xFEFFBF);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_UERR,      0,    0x1FF030);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_UERR_MASK, 0,    0x1FF030);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_CERR,      0,    0x11C1);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_ECAP + PCI_ERR_CAP, (PCI_ERR_CAP_ECRC_CHKC\n+                                               | PCI_ERR_CAP_ECRC_GENC), 0x15F);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_HLOG_1,    0,    0xFFFFFFFF);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_HLOG_2,    0,    0xFFFFFFFF);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_HLOG_3,    0,    0xFFFFFFFF);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_HLOG_4,    0,    0xFFFFFFFF);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_RERR,      0,    0x7F);\n+    RC_CONFIG_STICKY_RESET(PHB_AER_ESID,      0,    0xFFFFFFFF);\n+    RC_CONFIG_STICKY_RESET(PHB_DLF_STAT,      0,    0x807FFFFF);\n+    RC_CONFIG_STICKY_RESET(P16_STAT,          0,    0x1F);\n+    RC_CONFIG_STICKY_RESET(P16_LDPM,          0,    0xFFFF);\n+    RC_CONFIG_STICKY_RESET(P16_FRDPM,         0,    0xFFFF);\n+    RC_CONFIG_STICKY_RESET(P16_SRDPM,         0,    0xFFFF);\n+    RC_CONFIG_STICKY_RESET(P32_CTL,           0,    0x3);\n }\n \n+/* Apply sticky-mask to the reset-value and write to the reg-address */\n+#define STICKY_RST(addr, rst_val, sticky_mask) (phb->regs[addr >> 3] = \\\n+            ((phb->regs[addr >> 3] & sticky_mask) | (rst_val & ~sticky_mask)))\n+\n static void pnv_phb4_pbl_core_reset(PnvPHB4 *phb)\n {\n-    /* Zero all registers initially */\n+    /*\n+     * Zero all registers initially,\n+     * with sticky reset of certain registers.\n+     */\n     for (int i = PHB_PBL_CONTROL ; i <= PHB_PBL_ERR1_STATUS_MASK ; i += 8) {\n-        phb->regs[i >> 3] = 0x0;\n+        switch (i) {\n+        case PHB_PBL_ERR_STATUS:\n+            break;\n+        case PHB_PBL_ERR1_STATUS:\n+        case PHB_PBL_ERR_LOG_0:\n+        case PHB_PBL_ERR_LOG_1:\n+        case PHB_PBL_ERR_STATUS_MASK:\n+        case PHB_PBL_ERR1_STATUS_MASK:\n+            STICKY_RST(i, 0, PPC_BITMASK(0, 63));\n+            break;\n+        default:\n+            phb->regs[i >> 3] = 0x0;\n+        }\n     }\n+    STICKY_RST(PHB_PBL_ERR_STATUS, 0, \\\n+            (PPC_BITMASK(0, 9) | PPC_BITMASK(12, 63)));\n \n     /* Set specific register values */\n     phb->regs[PHB_PBL_CONTROL       >> 3] = 0xC009000000000000;\n@@ -700,6 +754,17 @@ static void pnv_phb4_reg_write(void *opaque, hwaddr off, uint64_t val,\n         }\n         break;\n \n+    /*\n+     * Writing bits to a 1 in this register will inject the error corresponding\n+     * to the bit that is written. The bits will automatically clear to 0 after\n+     * the error is injected. The corresponding bit in the Error Status Reg\n+     * should also be set automatically when the error occurs.\n+     */\n+    case PHB_PBL_ERR_INJECT:\n+        phb->regs[PHB_PBL_ERR_STATUS >> 3] = phb->regs[off >> 3];\n+        phb->regs[off >> 3] = 0;\n+        break;\n+\n     /* Silent simple writes */\n     case PHB_ASN_CMPM:\n     case PHB_CONFIG_ADDRESS:\n@@ -1620,11 +1685,65 @@ static PCIIOMMUOps pnv_phb4_iommu_ops = {\n     .get_address_space = pnv_phb4_dma_iommu,\n };\n \n+static void pnv_phb4_err_reg_reset(PnvPHB4 *phb)\n+{\n+    STICKY_RST(PHB_ERR_STATUS,       0, PPC_BITMASK(0, 33));\n+    STICKY_RST(PHB_ERR1_STATUS,      0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_ERR_STATUS_MASK,  0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_ERR1_STATUS_MASK, 0, PPC_BITMASK(0, 63));\n+\n+    STICKY_RST(PHB_TXE_ERR_STATUS,       0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_TXE_ERR1_STATUS,      0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_TXE_ERR_STATUS_MASK,  0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_TXE_ERR1_STATUS_MASK, 0, PPC_BITMASK(0, 63));\n+\n+    STICKY_RST(PHB_RXE_ARB_ERR_STATUS,       0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_ARB_ERR1_STATUS,      0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_ARB_ERR_LOG_0,        0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_ARB_ERR_LOG_1,        0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_ARB_ERR_STATUS_MASK,  0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_ARB_ERR1_STATUS_MASK, 0, PPC_BITMASK(0, 63));\n+\n+    STICKY_RST(PHB_RXE_MRG_ERR_STATUS,       0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_MRG_ERR1_STATUS,      0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_MRG_ERR_STATUS_MASK,  0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_MRG_ERR1_STATUS_MASK, 0, PPC_BITMASK(0, 63));\n+\n+    STICKY_RST(PHB_RXE_TCE_ERR_STATUS,       0, PPC_BITMASK(0, 35));\n+    STICKY_RST(PHB_RXE_TCE_ERR1_STATUS,      0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_TCE_ERR_LOG_0,        0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_TCE_ERR_LOG_1,        0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_TCE_ERR_STATUS_MASK,  0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_RXE_TCE_ERR1_STATUS_MASK, 0, PPC_BITMASK(0, 63));\n+}\n+\n+static void pnv_phb4_pcie_stack_reg_reset(PnvPHB4 *phb)\n+{\n+    STICKY_RST(PHB_PCIE_CRESET, 0xE000000000000000, \\\n+                        (PHB_PCIE_CRESET_PERST_N | PHB_PCIE_CRESET_REFCLK_N));\n+    STICKY_RST(PHB_PCIE_DLP_ERRLOG1,             0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_PCIE_DLP_ERRLOG2,             0, PPC_BITMASK(0, 31));\n+    STICKY_RST(PHB_PCIE_DLP_ERR_STATUS,          0, PPC_BITMASK(0, 15));\n+}\n+\n+static void pnv_phb4_regb_err_reg_reset(PnvPHB4 *phb)\n+{\n+    STICKY_RST(PHB_REGB_ERR_STATUS,       0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_REGB_ERR1_STATUS,      0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_REGB_ERR_LOG_0,        0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_REGB_ERR_LOG_1,        0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_REGB_ERR_STATUS_MASK,  0, PPC_BITMASK(0, 63));\n+    STICKY_RST(PHB_REGB_ERR1_STATUS_MASK, 0, PPC_BITMASK(0, 63));\n+}\n+\n static void pnv_phb4_reset(Object *obj, ResetType type)\n {\n     PnvPHB4 *phb = PNV_PHB4(obj);\n \n     pnv_phb4_pbl_core_reset(phb);\n+    pnv_phb4_err_reg_reset(phb);\n+    pnv_phb4_pcie_stack_reg_reset(phb);\n+    pnv_phb4_regb_err_reg_reset(phb);\n }\n \n static void pnv_phb4_instance_init(Object *obj)\ndiff --git a/include/hw/pci-host/pnv_phb4_regs.h b/include/hw/pci-host/pnv_phb4_regs.h\nindex 6892e21cc9..df5e86d29a 100644\n--- a/include/hw/pci-host/pnv_phb4_regs.h\n+++ b/include/hw/pci-host/pnv_phb4_regs.h\n@@ -344,17 +344,32 @@\n #define   PHB_RC_CONFIG_SIZE                    0x800\n \n #define PHB_AER_ECAP                            0x100\n+#define PHB_AER_UERR                            0x104\n+#define PHB_AER_UERR_MASK                       0x108\n+#define PHB_AER_CERR                            0x110\n #define PHB_AER_CAPCTRL                         0x118\n+#define PHB_AER_HLOG_1                          0x11C\n+#define PHB_AER_HLOG_2                          0x120\n+#define PHB_AER_HLOG_3                          0x124\n+#define PHB_AER_HLOG_4                          0x128\n+#define PHB_AER_RERR                            0x130\n+#define PHB_AER_ESID                            0x134\n #define PHB_SEC_ECAP                            0x148\n #define PHB_LMR_ECAP                            0x1A0\n #define PHB_LMR_CTLSTA_2                        0x1AC\n #define PHB_LMR_CTLSTA_16                       0x1E4\n #define PHB_DLF_ECAP                            0x1E8\n #define PHB_DLF_CAP                             0x1EC\n+#define PHB_DLF_STAT                            0x1F0\n #define P16_ECAP                                0x1F4\n+#define P16_STAT                                0x200\n+#define P16_LDPM                                0x204\n+#define P16_FRDPM                               0x208\n+#define P16_SRDPM                               0x20C\n #define P32_ECAP                                0x224\n #define P32_CAP                                 0x228\n-\n+#define P32_CTL                                 0x22C\n+#define P32_STAT                                0x230\n /* PHB4 REGB registers */\n \n /* PBL core */\n@@ -388,8 +403,7 @@\n #define   PHB_PCIE_CRESET_PBL           PPC_BIT(2)\n #define   PHB_PCIE_CRESET_PERST_N       PPC_BIT(3)\n #define   PHB_PCIE_CRESET_PIPE_N        PPC_BIT(4)\n-\n-\n+#define   PHB_PCIE_CRESET_REFCLK_N      PPC_BIT(8)\n #define PHB_PCIE_HOTPLUG_STATUS         0x1A20\n #define   PHB_PCIE_HPSTAT_PRESENCE      PPC_BIT(10)\n \ndiff --git a/tests/qtest/pnv-phb4-test.c b/tests/qtest/pnv-phb4-test.c\nindex 8cd6c1bc59..419f34987a 100644\n--- a/tests/qtest/pnv-phb4-test.c\n+++ b/tests/qtest/pnv-phb4-test.c\n@@ -22,6 +22,19 @@\n #define PNV_P10_CHIP_INDEX      3\n #define PHB4_XSCOM              0x40084800ull\n \n+/*\n+ * Indirect XSCOM write:\n+ * - Write 'Indirect Address Register' with register-offset to write.\n+ * - Write 'Indirect Data Register' with the value.\n+ */\n+static void pnv_phb_xscom_write(QTestState *qts, const PnvChip *chip,\n+        uint64_t scom, uint32_t indirect_addr, uint32_t indirect_data,\n+        uint64_t reg, uint64_t val)\n+{\n+    qtest_writeq(qts, pnv_xscom_addr(chip, (scom >> 3) + indirect_addr), reg);\n+    qtest_writeq(qts, pnv_xscom_addr(chip, (scom >> 3) + indirect_data), val);\n+}\n+\n /*\n  * Indirect XSCOM read::\n  * - Write 'Indirect Address Register' with register-offset to read.\n@@ -35,6 +48,11 @@ static uint64_t pnv_phb_xscom_read(QTestState *qts, const PnvChip *chip,\n     return qtest_readq(qts, pnv_xscom_addr(chip, (scom >> 3) + indirect_data));\n }\n \n+#define PHB4_XSCOM_WRITE(a, v) pnv_phb_xscom_write(qts, \\\n+                                   &pnv_chips[PNV_P10_CHIP_INDEX], PHB4_XSCOM, \\\n+                                   PHB_SCOM_HV_IND_ADDR, PHB_SCOM_HV_IND_DATA, \\\n+                                   PPC_BIT(0) | (a), (v))\n+\n #define PHB4_XSCOM_READ(a) pnv_phb_xscom_read(qts, \\\n                                    &pnv_chips[PNV_P10_CHIP_INDEX], PHB4_XSCOM, \\\n                                    PHB_SCOM_HV_IND_ADDR, PHB_SCOM_HV_IND_DATA, \\\n@@ -46,6 +64,26 @@ static void phb4_reset_test(QTestState *qts)\n     g_assert_cmpuint(PHB4_XSCOM_READ(PHB_PBL_CONTROL), ==, 0xC009000000000000);\n }\n \n+/* Check sticky-reset */\n+static void phb4_sticky_rst_test(QTestState *qts)\n+{\n+    uint64_t val;\n+\n+    /*\n+     * Sticky reset test of PHB_PBL_ERR_STATUS.\n+     *\n+     * Write all 1's to reg PHB_PBL_ERR_INJECT.\n+     * Updated value will be copied to reg PHB_PBL_ERR_STATUS.\n+     *\n+     * Reset PBL core by setting PHB_PCIE_CRESET_PBL in reg PHB_PCIE_CRESET.\n+     * Verify the sticky bits are still set.\n+     */\n+    PHB4_XSCOM_WRITE(PHB_PBL_ERR_INJECT, PPC_BITMASK(0, 63));\n+    PHB4_XSCOM_WRITE(PHB_PCIE_CRESET, PHB_PCIE_CRESET_PBL); /*Reset*/\n+    val = PHB4_XSCOM_READ(PHB_PBL_ERR_STATUS);\n+    g_assert_cmpuint(val, ==, (PPC_BITMASK(0, 9) | PPC_BITMASK(12, 63)));\n+}\n+\n static void phb4_tests(void)\n {\n     QTestState *qts = NULL;\n@@ -55,6 +93,9 @@ static void phb4_tests(void)\n     /* Check reset value of a register */\n     phb4_reset_test(qts);\n \n+    /* Check sticky reset of a register */\n+    phb4_sticky_rst_test(qts);\n+\n     qtest_quit(qts);\n }\n \n",
    "prefixes": [
        "v3",
        "3/9"
    ]
}