From patchwork Thu May 2 15:29:18 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: CLEMENT MATHIEU--DRIF X-Patchwork-Id: 13651821 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id D6BE0C04FFE for ; Thu, 2 May 2024 15:33:21 +0000 (UTC) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1s2YNY-0003oF-Ar; Thu, 02 May 2024 11:29:48 -0400 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1s2YNW-0003n1-PW for qemu-devel@nongnu.org; Thu, 02 May 2024 11:29:46 -0400 Received: from smarthost4.eviden.com ([80.78.11.85]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1s2YNU-0005ys-UQ for qemu-devel@nongnu.org; Thu, 02 May 2024 11:29:46 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=eviden.com; i=@eviden.com; q=dns/txt; s=mail; t=1714663785; x=1746199785; h=from:to:cc:subject:date:message-id:references: in-reply-to:content-id:content-transfer-encoding: mime-version; bh=9FxV2pX7chRK0bdJDSW+G+9YHH7CXug/vkDSNtE3+PE=; b=b16vJBOm5WRvRuG3FoKkAQBiRcdoQIORmpPJ4VkxQLSOlyJW0e9i1zLD Qap56Z7FwEaSJZJmVPcywKmOk2Lx9wuJJVSFLQ97wTXv949gFeJTl6hsu RU5iR4b35dCMHBRsZhYE7LsbK+WlK3OCl+4FHum18w95FGYgqEnUZZmVI UByBbv+Uk6FhmOU0RhscJvOkWq4WzFTR1iH/XLH/R71e48Jvl8JYVvovV TfYM/gp/ii5LGrz4daDxUyPnN+8OVbi+NSIsPbdOUNRtnpY80JIOtUx5M UnvIgyc9h5EVv7nbhJ/edwhqVuDBhEQGZfs9/V9cvmWp1KC5+cPDF+u1P w==; X-IronPort-AV: E=Sophos;i="6.07,247,1708383600"; d="scan'208";a="11785881" X-MGA-submission: MDE4PCaUBIkpJLsr4UMsDamwzf9UlnKxuQ/fll2Wy2JUwWj2Vqroy4SHbVKDn3bqwBJWs9vQ1v1moN59drvqAQtyIkoi/POQhLHJjWFlO1/hcne83scLVjihzayxK8EJTs1ZAHXLzH/ZnRC05NeeDwJrDUDq04nx0vMD+9Gd/X/oAw== Received: from mail-db8eur05lp2104.outbound.protection.outlook.com (HELO EUR05-DB8-obe.outbound.protection.outlook.com) ([104.47.17.104]) by smarthost4.eviden.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 02 May 2024 17:29:21 +0200 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=bn5vAuldfbP+LAIst3Z8c6bfATUo2NTQoVAjVWPItnfZMazQA+IWdQuBlV9I6bGSL1u4jh2z2HTszVmsajjy9hw3Kq4alHQ63WWzYnzhcBhTVn3IiDaCXNX/RWQE2RAu1rGi2F5fOmhbisKaVu619F1WCYszGtTzGk1h/Xi9mADXXnpjeoz3iSzdNllVnukg/+0sEfliD1lGIoTJMzLBveBN7dibRoNRYYkfOIoG6CUXB4bFFMZqYL/AeAk7U6HkB35rNCO6pFjq0GnJD42byXSx3w59MtrXRUCE8syGrTe3GMEhDInCKEj/SZuET1Bbk+qcE4X4dicQI6svkFgM1A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; 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; bh=9FxV2pX7chRK0bdJDSW+G+9YHH7CXug/vkDSNtE3+PE=; b=ZbFmmZObTOlj69jZKyw0hPOzL568tBVOk23+vsKZsDHBKxO4/SRdN38fQZLXOX7ZKwnhNd1yoauPSTX1Xt8pRSIGhQlGEiRSGrC4LqNLUZdi9xATo9h4xdrClkxiCkQzLGasSPGPXtLlRTEZyQBLrw3Dwsu6lwNr4jFqQj0LBIX3Jlup7G3+aLUHgXeIcz2DgFoq/Xa1vBYUTQpzIaTCjbIwwRW2qD/t+7dxGtgi0bjHNB5mA5WKVLjU0WMWVZ82/WWPPp2y63ouFmSJwty6PPigtDq+QJqmhJRp+c8Ahd2eiIaQSxKfXQECkM8u1TD5xp5A1z0qT2be6pEcQUQSCQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=eviden.com; dmarc=pass action=none header.from=eviden.com; dkim=pass header.d=eviden.com; arc=none Received: from AM8PR07MB7602.eurprd07.prod.outlook.com (2603:10a6:20b:24b::7) by PAWPR07MB9661.eurprd07.prod.outlook.com (2603:10a6:102:389::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7544.29; Thu, 2 May 2024 15:29:18 +0000 Received: from AM8PR07MB7602.eurprd07.prod.outlook.com ([fe80::fbd7:ca71:b636:6f9d]) by AM8PR07MB7602.eurprd07.prod.outlook.com ([fe80::fbd7:ca71:b636:6f9d%4]) with mapi id 15.20.7519.035; Thu, 2 May 2024 15:29:18 +0000 From: CLEMENT MATHIEU--DRIF To: "qemu-devel@nongnu.org" CC: "jasowang@redhat.com" , "zhenzhong.duan@intel.com" , "kevin.tian@intel.com" , "yi.l.liu@intel.com" , "joao.m.martins@oracle.com" , "peterx@redhat.com" , CLEMENT MATHIEU--DRIF Subject: [PATCH ats_vtd v1 08/24] pcie: add helper to declare PASID capability for a pcie device Thread-Topic: [PATCH ats_vtd v1 08/24] pcie: add helper to declare PASID capability for a pcie device Thread-Index: AQHanKV/ZpfW7p59SkGnAmV2rL6amQ== Date: Thu, 2 May 2024 15:29:18 +0000 Message-ID: <20240502152810.187492-9-clement.mathieu--drif@eviden.com> References: <20240502152810.187492-1-clement.mathieu--drif@eviden.com> In-Reply-To: <20240502152810.187492-1-clement.mathieu--drif@eviden.com> Accept-Language: en-GB, fr-FR, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=eviden.com; x-ms-publictraffictype: Email x-ms-traffictypediagnostic: AM8PR07MB7602:EE_|PAWPR07MB9661:EE_ x-ms-office365-filtering-correlation-id: 7a3182d0-e6d5-48e2-f6c8-08dc6abca218 x-ms-exchange-senderadcheck: 1 x-ms-exchange-antispam-relay: 0 x-microsoft-antispam: BCL:0; ARA:13230031|366007|1800799015|376005|38070700009; x-microsoft-antispam-message-info: =?utf-8?q?fyJTLK0Or42BIJoMRK+UhvzQBLetRHp?= =?utf-8?q?OzgoVEvEa5sHDsRQoct/nzmUQAXj6nc6mezlIaJBAoPNvg1HVnhPBpHQpPNLUfzWB?= =?utf-8?q?wdMRJJcZOKPEqjiaToNSXoALoD7kpNtD6bZE95vTWo6QlqihxSizF4l253khe5Pqn?= =?utf-8?q?j79fU5cmvxQfBehVtZRQ7OS5+E8xYHdj/fh1/LSYzVxM1HMEskgHhiSjnz8Ao7ehC?= =?utf-8?q?mCzUmKxOY9Cd5T0+rtV0IKeO09yZ4YMC1gN0xk2OVbyPDXs4I+Wa48u2v2ztjctpQ?= =?utf-8?q?rw8jNeJXy+rjK9qFbRTpP+awT+B639/9KIBbpQQcEGWDvi2rnwgNYB32mjesoqma2?= =?utf-8?q?4wUTUqoN+xF/Am+U6tSw5sSAZbsb+Rdk3xHawlG9rb4tQ6udA4qEIopdvRUFOqKll?= =?utf-8?q?/53VFNcgZgZrK3uKRssKpRoe039n6LTIppV9ZGLr5f1hYxdrieSI7hekCoAzdTon0?= =?utf-8?q?Wgbs/8LWiAy7JRLLpZx+Rsa3z80hxf/odipKCnMPkA9aWGXtVGa8yQ0XfIofu42Z3?= =?utf-8?q?+7yUx4hR1Ftds70whRA7CFu3+/9VlPimRKV5zxJ/fLPKOvsmtffptT5D9mMPhOTJj?= =?utf-8?q?htJpugasWPUfYKgtW7eWa69dmfZQ0DY74udIDbnxYNwKhGSnpcJWsZD8hS3EgDW8I?= =?utf-8?q?jsHeg1Yg4oeube0QCgAcQf25c/+IkhFtfhDDbmnfh01Hxpc8ysS5DPeG2ruIZgOkr?= =?utf-8?q?U96F+5DO/zaP8PT2M9DPpvbN5cAnM1jz3ubxJrI4ue6Vz+NRPVQMZmWb5IdurgafE?= =?utf-8?q?BqfaSyJYT7C4iZk+EKU3sENduUIq37SNcMpS5D2V7sS/ayBN+Bd0BwNppCXVSsGHV?= =?utf-8?q?eRaMDet8Npv5s7f1/vAq3Xd/bF5TBtfee1nFa8ToW9UXUgQJsogUv5DIKICh/rtgS?= =?utf-8?q?hg0QETQthqKCSUjKSXcwIgfyy2a0lY+l5DWnaewOXcqUEv9qsQdoxA37y4gKv3+xP?= =?utf-8?q?r271dO96ZkBNjnmyrSrzEd3TAUpk+2AfJ1pu3SA67iaFepOWzblnAgxJX2uQeEwEC?= =?utf-8?q?15+dae44lgXyNM43ByOdbCU3N8RtvPO7QFldzMUQlkDEI5KO4f3LlQwigvFS4lkzf?= =?utf-8?q?1S2G17tfSlJL6iNSQVm0DaehelqbEiU5wZw6RMNHjSM4AfHsnVANln1Z8SwZKZVRg?= =?utf-8?q?hlA2zStlqdqNP/2dUNovmsxTyzwLmJaqmipEALlpmPvfFNsWhZQIHMAuNZC167msu?= =?utf-8?q?Ld/dFaZkBkkQxaXfdqlb4u0Fz3YAQvaI3XMImZa/1Ekvm+CHDXrZlagMLC9e/gRfs?= =?utf-8?q?wncC3z8jPcIF3zBSI/Qqj/lTOPa0xEJlkVg=3D=3D?= x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:AM8PR07MB7602.eurprd07.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230031)(366007)(1800799015)(376005)(38070700009); DIR:OUT; SFP:1101; x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?utf-8?q?RNFQZsFOy1GVEnLUoLc24PK7ESOg?= =?utf-8?q?Gl2C/67nNezHv7LXboZQPziU/QlIxvscJyR9CfvdoOgHdYwBD5uTpRwVMgZVP4gKb?= =?utf-8?q?tipt9o7plvOMy542oDSCTzgZ+hjvO3tRwBwmT72yTEKRNORriSU/HF3XqUkDaX3Y3?= =?utf-8?q?uFAURMBv0Y1n8+ZFjOx7JO/ed9aGwLA53WJb1jJjNjdEBYDOR2L91BEjUOg+YF9h3?= =?utf-8?q?1eWo1nhIeFaf5QPrg07kauLSypSiCL9nU9zmeo01o5qT/y/f5M/eTsbGgIaHf4EmO?= =?utf-8?q?AyumKZUs7Xn3Mqhh5vr6nMFdCqO9ljSa6YlXlFsIY5sQAcKij0HC95h10bxaiO5tD?= =?utf-8?q?jUO482tuqD8GhyTG2pz9VJtWir9E8IJUE4ANHJoKcd/G6P2sBlNOyuPVwBfH4HV+Q?= =?utf-8?q?Xqj7r5NgTSiOUFBiykSa9AQlv45jQPKWbit/VkRxDNw8qsIM5Ax7VLzBBSAtZLGr9?= =?utf-8?q?6udpwhhELdEUY8SKsn0K8h1EFgXjI9ADf7vvtTrFnsXPbHTX68Iielz5sMB64rlHF?= =?utf-8?q?clHHGiBZrMMZZpAIf2TtJdFfXkbpn/ZDituSLapmHq+Ulj08/mpTIPXsfJ/KlbJ3k?= =?utf-8?q?Cy+w3Lei1lV3LM8cqJS9e8xOitbbn5pOvC2iGlN9d1p3QrveH2f4eNyonZayLOi90?= =?utf-8?q?983E+H0sPb+xX+bYyKJ0fGQN9iXIHkrPMc4qRhaUehY99sVtyeAbRJ6Hfh0iY0l3+?= =?utf-8?q?AbV6ZLF2plZv8aXpaFSFtJJylSVlumiODw1qNI3u01twAzRfoKQHJfqCIZRlJljOr?= =?utf-8?q?Sv+rdLV7YFfXve5lOBLXx13CrYeNI9D7CxFoPb4Zk7q0WLFXJf+3tjjwHNyhiX1ob?= =?utf-8?q?J2XRDFP3kU9jErUPOWflKkpoTolt/gkPXBkf++MtWv8b/T6tJ8T9qUMuur7Xy+uAl?= =?utf-8?q?sJQX0b2PeDEj6rU7N/61w82t2w/lPuFPZhHQtfMNKAtRhhVpPpS8aeelhXWRHsrUN?= =?utf-8?q?G4YyrZmibPWhkTD+0XjnCy8pZ/ra1cN0vRqFKdgT6nv6YKxALRfAhhLPnrVw+XSbL?= =?utf-8?q?sDKmmyV7dWj6vzdQuo+Q6gsDdIOPqGwijy9TTCqRPCFh1TSgRd0M1JcxHTMDUxu5L?= =?utf-8?q?WpMoHCSv/7t1UdGtam/tqo8aUTcb8kejcdgk6klBAgA+6W8kg3UXa3pLfNaQ/6Mso?= =?utf-8?q?2GoNI+a3e6e78POgzFu+kgkgaPCGiOUvUXA8fGnju5kvVi9KmaXGa0IsPDZd1yqHt?= =?utf-8?q?6cJNnVwBYNXXnsU529QzGzwY1MK9pUyXSlKvLvmCi1+ENLot/N1tw8jiabwdIYBCS?= =?utf-8?q?wKRYOmmjpqikvdP77+qHM7Esk7SmYCwwwltNK/6z/cjhnO6j1uFaWRvfMm7HJ3ECG?= =?utf-8?q?LGsaJL8ZhuAJP0xwbsFQWDsp/gVsmBn2vX3n1N7n4e+s1szTmXh8RoBFk69HNWszv?= =?utf-8?q?H6jSZkmJVpu5czSRa0ORd7vyoQA2vtWp1DRZ3y1YUxqVn72m5fZAecKhiIC+BMzgh?= =?utf-8?q?hzgQtqY8t071FQKoJbdF8xRLKBsd7+h9Puz7IjoxnTTBn8ysPQaHdkGkexgGnWQkg?= =?utf-8?q?/jmuOXt2sOuY0+Rt4sEY30jMlM8J6XuWZCiuqS/9QBLXMn31j6I3qfw=3D?= Content-ID: <750248B27314B54590BA69815BB74B75@eurprd07.prod.outlook.com> MIME-Version: 1.0 X-OriginatorOrg: eviden.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: AM8PR07MB7602.eurprd07.prod.outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: 7a3182d0-e6d5-48e2-f6c8-08dc6abca218 X-MS-Exchange-CrossTenant-originalarrivaltime: 02 May 2024 15:29:18.5251 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 7d1c7785-2d8a-437d-b842-1ed5d8fbe00a X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: l2xVAx4F+S9BZz+OtF2ybYERV0A6uReOqjyYMkvf0jr2BMQKAQCkgbiq5MJ6ooEZBwHR5DUBppuWTfGvFok6XuSY6GiFIcYUFLIVfJHTOHiKq++fixVsiv/OYISc9p5M X-MS-Exchange-Transport-CrossTenantHeadersStamped: PAWPR07MB9661 Received-SPF: pass client-ip=80.78.11.85; envelope-from=clement.mathieu--drif@eviden.com; helo=smarthost4.eviden.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, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, SPF_HELO_PASS=-0.001, 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: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Sender: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Signed-off-by: Clément Mathieu--Drif --- hw/pci/pcie.c | 24 ++++++++++++++++++++++++ include/hw/pci/pcie.h | 6 +++++- include/hw/pci/pcie_regs.h | 3 +++ 3 files changed, 32 insertions(+), 1 deletion(-) diff --git a/hw/pci/pcie.c b/hw/pci/pcie.c index 4b2f0805c6..c8e9d4c0f7 100644 --- a/hw/pci/pcie.c +++ b/hw/pci/pcie.c @@ -1177,3 +1177,27 @@ void pcie_acs_reset(PCIDevice *dev) pci_set_word(dev->config + dev->exp.acs_cap + PCI_ACS_CTRL, 0); } } + +/* PASID */ +void pcie_pasid_init(PCIDevice *dev, uint16_t offset, uint8_t pasid_width, + bool exec_perm, bool priv_mod) +{ + assert(pasid_width <= PCI_EXT_CAP_PASID_MAX_WIDTH); + static const uint16_t control_reg_rw_mask = 0x07; + uint16_t capability_reg = pasid_width; + + pcie_add_capability(dev, PCI_EXT_CAP_ID_PASID, PCI_PASID_VER, offset, + PCI_EXT_CAP_PASID_SIZEOF); + + capability_reg <<= PCI_EXT_CAP_PASID_SIZEOF; + capability_reg |= exec_perm ? PCI_PASID_CAP_EXEC : 0; + capability_reg |= priv_mod ? PCI_PASID_CAP_PRIV : 0; + pci_set_word(dev->config + offset + PCI_PASID_CAP, capability_reg); + + /* Everything is disabled by default */ + pci_set_word(dev->config + offset + PCI_PASID_CTRL, 0); + + pci_set_word(dev->wmask + offset + PCI_PASID_CTRL, control_reg_rw_mask); + + dev->exp.pasid_cap = offset; +} diff --git a/include/hw/pci/pcie.h b/include/hw/pci/pcie.h index 11f5a91bbb..c59627d556 100644 --- a/include/hw/pci/pcie.h +++ b/include/hw/pci/pcie.h @@ -69,8 +69,9 @@ struct PCIExpressDevice { uint16_t aer_cap; PCIEAERLog aer_log; - /* Offset of ATS capability in config space */ + /* Offset of ATS and PASID capabilities in config space */ uint16_t ats_cap; + uint16_t pasid_cap; /* ACS */ uint16_t acs_cap; @@ -147,4 +148,7 @@ void pcie_cap_slot_unplug_cb(HotplugHandler *hotplug_dev, DeviceState *dev, Error **errp); void pcie_cap_slot_unplug_request_cb(HotplugHandler *hotplug_dev, DeviceState *dev, Error **errp); + +void pcie_pasid_init(PCIDevice *dev, uint16_t offset, uint8_t pasid_width, + bool exec_perm, bool priv_mod); #endif /* QEMU_PCIE_H */ diff --git a/include/hw/pci/pcie_regs.h b/include/hw/pci/pcie_regs.h index 9d3b6868dc..0a86598f80 100644 --- a/include/hw/pci/pcie_regs.h +++ b/include/hw/pci/pcie_regs.h @@ -86,6 +86,9 @@ typedef enum PCIExpLinkWidth { #define PCI_ARI_VER 1 #define PCI_ARI_SIZEOF 8 +/* PASID */ +#define PCI_PASID_VER 1 +#define PCI_EXT_CAP_PASID_MAX_WIDTH 20 /* AER */ #define PCI_ERR_VER 2 #define PCI_ERR_SIZEOF 0x48