From patchwork Thu Aug 18 19:42:37 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Suthikulpanit, Suravee" X-Patchwork-Id: 74194 Delivered-To: patch@linaro.org Received: by 10.140.29.52 with SMTP id a49csp70671qga; Thu, 18 Aug 2016 18:19:39 -0700 (PDT) X-Received: by 10.98.62.65 with SMTP id l62mr9384792pfa.2.1471569579253; Thu, 18 Aug 2016 18:19:39 -0700 (PDT) Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c9si5227288pas.141.2016.08.18.18.19.35; Thu, 18 Aug 2016 18:19:39 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@amdcloud.onmicrosoft.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755179AbcHSBT0 (ORCPT + 27 others); Thu, 18 Aug 2016 21:19:26 -0400 Received: from mail-bl2nam02on0079.outbound.protection.outlook.com ([104.47.38.79]:54432 "EHLO NAM02-BL2-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1755047AbcHSBTV (ORCPT ); Thu, 18 Aug 2016 21:19:21 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amdcloud.onmicrosoft.com; s=selector1-amd-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=pRYkBBDt/1RNpM4pwEnrjEwU4XJiyjGK5vn5njyiB6U=; b=V0XMd/p65RhD1EnTAAX6itHsfQOWUd6Yu/6aGuLHnVAh1GsApDTsZNqGWrqJNE9n4gpRH5mxkz2tVW+NpAMeQ7A5VVIlZQcvkKQy/+UIklIRfOxxfA7aztqdUw6uqtF79jYMwiePdk4C9TAhga22lZz6YpG86D1xC1PnmxMwwCw= Authentication-Results: spf=none (sender IP is ) smtp.mailfrom=Suravee.Suthikulpanit@amd.com; Received: from localhost.localdomain (114.109.128.54) by MWHPR12MB1453.namprd12.prod.outlook.com (10.172.55.22) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA_P384) id 15.1.587.9; Thu, 18 Aug 2016 19:43:40 +0000 From: Suravee Suthikulpanit To: , , , CC: , , , Suravee Suthikulpanit Subject: [PART2 PATCH v6 05/12] iommu/amd: Detect and initialize guest vAPIC log Date: Thu, 18 Aug 2016 14:42:37 -0500 Message-ID: <1471549364-6672-6-git-send-email-Suravee.Suthikulpanit@amd.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1471549364-6672-1-git-send-email-Suravee.Suthikulpanit@amd.com> References: <1471549364-6672-1-git-send-email-Suravee.Suthikulpanit@amd.com> MIME-Version: 1.0 X-Originating-IP: [114.109.128.54] X-ClientProxiedBy: KL1PR0201CA0016.apcprd02.prod.outlook.com (10.167.53.154) To MWHPR12MB1453.namprd12.prod.outlook.com (10.172.55.22) X-MS-Office365-Filtering-Correlation-Id: 6c78f3fc-3e58-4a9e-4d93-08d3c79ff5cb X-Microsoft-Exchange-Diagnostics: 1; MWHPR12MB1453; 2:pVzggY7/Ri8fzZxS3wYSaE7pRHKe6McKhmtCLqi1d4/xKKmHJRPML6QqbyXDSinproFmcxZ5Yk+jxixMzx9u4VtugFYG11sr9OS53fmLvSazAbMwef1tTgsHdBtrfsID9EP5OHAMo7rakJ6gjUfTv0wOrvixXuHhJFRg0uk5sTEPm0J/sqiZCBNciqEhs3FK; 3:hFGJiE8DKWQKXD6YhZ3ha/fT2+HGrSxf8jB6omLp0fgJlvFLRIzcdZFJ9N5jHZDguc47BIQEHetG3N+PW6hYCfzzzaMItI0C/QaLBuG8EEsANUZTGZY8Hopfi9GVRHN0 X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:MWHPR12MB1453; X-Microsoft-Exchange-Diagnostics: 1; MWHPR12MB1453; 25:jz9j/P4Q0+8Lzty4gyj55Vu2B8iwSHHDNlViGRjfoLUjFY5OV4aLAps/AUovf4n5e6F25MVyDQIiNMERazjBSfhXDErgcv9wRj1NNY5jW3N72bSMLzaHx9AhmdSVx/vOsv0SrrjeY5fLGzaBseqB1yqvkagtKXJFAGsLqdcpOInwjUAPtWyoqtxeyutLXEK7xAG8XBuoD05DYQIncjfhoS69z3sd2/zWRymUfNm64eg8CMIBbPCuZxbw59Lcjt1SjkdhAmW006UzcgtWme8L9eN5SgVZFVR9ab8ktFZw0irjq0p5NdC6z6Hu9MaZqB+y43qnkyyF26canseujh1dl95J52vUgijMkslp9IbrQ9O+xtO1kB2ihQSCcoXZH5xyOarh/Crnk7jkzOKVa60cT3POPT2W+CuQlYILOiNR3PA2gVAVZbOZbHGViAFIOwijHIbxMYfS0/5R1zE+IFDgz7mQtXfU25qKa5f5Krvevlz/mW1dCBgZFFce1m9UH1CafljexSKDE37wwEi/7FkLe+nqMYbhKXR4wN8ciKllXFOrQ2ZUTNB5z1gbpqRScVyiITwb/8o5HtL5amWz3mIyBy+4Ceo8jZK2gDiTC2noSFhJ4OmIoZTPJMdiBpm8T4No7T0sLC1auA0HDy14G5Sab9sY0ha8ptiFtQJ6tF3wD4Je1yt/YS2+JjZzEq12VSB5QI/oJluHryW3m4OeIbTpquzF8Kul2qINMcmPdJWslOu4YwasXvKr8n6yndPzPcxv7sVcKHouZqyHC94wS15wyfjfl+Hs9iChtDQ51T+RzMM= X-Microsoft-Exchange-Diagnostics: 1; MWHPR12MB1453; 31:aymidTewiirRxNoNLD5Fbb2PgNVv+eRo2j9ibGlWuAppnhS2DIfVKYI7pL+XvmQOvO9G7QjETR5M8nromdv6pQWuHKiQeMMOnoI5Ofa/jhOrv74YXF7G9SoGcwcVmvcS5J3xGLpzIGTwWJGNjc08gvkHfEl5wsyywUYEaFhu0b05G6L9sUq41C/ARMjpqFiQJ4rYg5YVpK98vIww3ct37yigyBF285LyWhsIywq1ktA=; 20:/NXCPpoYrD0e6gvxYC+2U/NvwmSIAlnmSGR7TV2l67BRuNx48Q/WW9VyctsOOWBYih+bo7Y3anMS1bWX8QWqjfUQUanG54NoSsC55Hj90R3LmGwh3i6gCHD7Y9usdFDhj3SyxiI9PM4rab21jZbLkC9UdnHk/auzjeBvUcVpNBlySQCDDWODhvVB1BXgx5wBiRu8pqu59Lqesjt9Wp26AyLUecDog+0bKIEN86UG04jgE11vn7bv1c/UIYwIhCkAJHEpkz5ZD8qLfVN1X3SpokJfLc9ZF0LNHXp2op384jZBEEuGlXJdJ+jVgTmR7Rf+DdTndbPjEBQoSRlie04sgTLPNdd6TxqL7vcC83BfzhfdbBQStmAv8SPescycGZjS+pjPQcBahfRmekaDhRZELaRAwQ6xdZegTvR3h5cmQzsxZNFJxyk+dbGC0c/g5oCOms3zon1cVSdJucRjLlqb3/PNhF5N+g3UodVbmBa7558XdCc+9illKKkKcVMrQnQM X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(767451399110); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6040176)(601004)(2401047)(8121501046)(5005006)(10201501046)(3002001)(6055026); SRVR:MWHPR12MB1453; BCL:0; PCL:0; RULEID:; SRVR:MWHPR12MB1453; X-Microsoft-Exchange-Diagnostics: 1; MWHPR12MB1453; 4:peOfIjcS5h6//VhaRLq8Xg4nZWKsLNryqa5658J7BFJBELJJCV9+4V5WtQoUCJBNuSFQ5HBLpfFtklKbl18+ckoRKgqzjxc3MeQvEbIDgmQ7SI2ckHTszOBEwTB/NgH0gOeJwnNTPdTkEeWpeivpPIiCwdGEDeraATWXng+SGloeYpuTAPVQ3FVle1yBbyuIeVu0xvgeS9AHVK1IRp6ojeklhkUHHLjXs1flEs++gQkdVhywb1y2Ku/MtA1nRdmhDtrEsqVusPJx6QAehCHzGz5FPzplwBOvHg0q1usA3PivR1kn55PlZJvjCP0vmNcAI/fuuKhCQnG+7vNumiUuh30Z0lJQsCpMcDiC1LIbJe77TJnwgmrlwWVZb5nGZqsA8dQbnMvUA5nAImKBFQUHhIQtAdOqKJlfIZiSA2PdUEJy2wDftIpWgAfpEzPFErMp X-Forefront-PRVS: 0038DE95A2 X-Forefront-Antispam-Report: SFV:NSPM; SFS:(10009020)(4630300001)(6069001)(6009001)(7916002)(189002)(199003)(86362001)(42186005)(50226002)(19580395003)(586003)(68736007)(92566002)(3846002)(6116002)(189998001)(105586002)(8676002)(81156014)(81166006)(5003940100001)(47776003)(5001770100001)(2950100001)(97736004)(48376002)(77096005)(50986999)(50466002)(106356001)(36756003)(2201001)(305945005)(19580405001)(76176999)(7846002)(7736002)(4326007)(2906002)(66066001)(229853001)(101416001); DIR:OUT; SFP:1101; SCL:1; SRVR:MWHPR12MB1453; H:localhost.localdomain; FPR:; SPF:None; PTR:InfoNoRecords; MX:1; A:1; LANG:en; Received-SPF: None (protection.outlook.com: amd.com does not designate permitted sender hosts) X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; MWHPR12MB1453; 23:gAgwU3Xc7HxiTj6RVaO7FW997f1xZxPZg+KCP9Urx?= =?us-ascii?Q?MJUOw+Fu4YAS/MQv/fTUK/uFhHwqm1PDuoDtOaTn4q3VE+gdCefbFmaHpfRg?= =?us-ascii?Q?V4ldDfsz8XhP3DApJPa47HbwArscxt9nmDMS7WYPVgwC/D7uK42sexbee40L?= =?us-ascii?Q?TqhspdCsQzVkk8i3p+yHRncn/WAkQy5CZQLfjul0h3TVmC1glA7NtyYH4+gR?= =?us-ascii?Q?4B2/HinvcZtLZIPJooHNsFrHs4xS6wKk430LH1yILTtG2w6bfAzjl1gTsYCk?= =?us-ascii?Q?ipmNZFc3iY89jyaefuufySeionK9VofjASOrmtwZMvLROMFJfscMhoK0DIoX?= =?us-ascii?Q?Gza3k+bPY4Bm8vsOWi+mA17U2vmI5Rjc7q6b+moGQF9qzvKgUlYRea7X0FLg?= =?us-ascii?Q?w/7W3rFwCqthBBERbQgZA3tU2D5AnOQxLPGkPsELLbmqZ02oBO56c+ekqoga?= =?us-ascii?Q?fgtSXJkZzZ4f/bKWrzxtFiTImFZVbYINQbXaRFDVddoxQiABsrAB6xKn668Q?= =?us-ascii?Q?KB+fyZWR+Novqd3NTGET9P8htrXrlOXch7OPAQ2FqDbySvJkpZSLrl+Nz6rW?= =?us-ascii?Q?Sy2bas6SlejdP9KG6rK+OA1n+HMb0WPYyFuhmwYEKGKu7yjoczFjt0BjJWV8?= =?us-ascii?Q?LEropCYba+cUgmLN3aUo7/DcBO27/UhIuGkhPLnoF4uOnRe+txh1QWat+1EF?= =?us-ascii?Q?uY4nj761VsFHW5jE13Yy+4KzhsP5lWyBS//hJIJrJD/xj/9G6E+38EJ8LAXe?= =?us-ascii?Q?tnEgZOvXA6L3gu+y8Ura37rxJGZGWul2eERR/4xfYzCcEs7Mkh9kz+Y9iQzw?= =?us-ascii?Q?LPWFe0CHgeJN2OYxqqRu+AqV78evGbyJUi9GRVcwCrjMHl3BTnM0Ke7dY04M?= =?us-ascii?Q?6BNWIc9AHtLnnMUaiowr8cSO2yjCQ1CSyF3MGnxSIrPP5IqAHtiGtM68WuXS?= =?us-ascii?Q?BX6xkqHFCKEh+l6rAjlbqomMr0kOI0BzJ9LKAVcv+cJIOgCE1jUVHqIg/GbS?= =?us-ascii?Q?PqNxFzfOpUw7S1LlP4b6/KIQqyVFyun1N5ILg8fiC8IdL5pfI1Slf3+3Bam3?= =?us-ascii?Q?iVagUFcdeESv7IRPfxqha+GxhXK?= X-Microsoft-Exchange-Diagnostics: 1; MWHPR12MB1453; 6:yQpBQf89rYANBAKBXC8Vrwm6TEythc3VTA884pAmWC2t77wb+0Er/gBmmEGtO8ZCkJvas8/AZ3rx89Lo9jswCNMsduYnuyOpWPqIhY7ZOXsvN0herkEjFvuDKeas4M/0Gx3phsEYvWiPycSRoLz6zfEYmmHM6h+JVsQBDovous08hDMouiuvcYpEtnj/DTDTvmY4EWu8C6RnR5fLnnmZq+sbz5Bm4Z8F1o60nptYGcNghCL891eomiFdMna9NkmOZA3w6ZDZvBEKSSW6qSJI9Dx8nYl2O2ctrpc+JXCoWlX/JBwV3gKxtnGl85+bydTQLoQDlOX4lalzBbFz3WERng==; 5:CajHVVVWdI+MmlCI4TTaHkhssvoRLSAv+MJ87arLDoCrxVeCejNNzKU+Ir2mQSpXsctYRRsN93yfDTESN/xRZomAn119oPCl62i5S9FsT1FyAkHlLrOCKOefXUyaVspm7bBTOAzEB242v74rONpE8g==; 24:bnFXPEuXBlE/lsMT+tmzMS5GFMhfRYVs3jugO6AJE7WC1VjVvaWoizgpCDKPphnVE2Edd4Q7S/lJfaZTEUb0YapJZ/qpue/fspr4WFVhQ1c=; 7:cfAOmVcQEz6hrjOcDwjtWAexmx3yyVuwl2e7VZibRgpAaKlQyx1Kgvr+GkswVJmXYku9WUBjEASH8IwBLt73nTx4Sel4j/y13hgwwYrzipfH6xxdW2WKLm1ZKXEdJsuWRnbE+0/HpP00h3IgYHXnD+t2f+ZkiUf8eVW4aBCPbLwo+9XjaI++acaZM85e0n1KaijF9+73GRV1wDJaDVtOMo0PUESbcte1Ete+2uP63Y7Tmj36a8DdzhwXq33JKv7S SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; MWHPR12MB1453; 20:HhenuTfaWsjEgjJ8X3OGCbGPKxA4INgXqgILLTZs0FQ/4u0gvC16c7bQ4dt8LRBBh+gP/IAEaEc4VAJaJZ9omjVCsoY3JNymbdET8WRAVMu7JUTr2xtbl6kJEVo1VJZ6jXBF0gkr2eeysyuOtLwEWD8BVDkc0Xhow9V7wonz2zNk+Ssal6le47WFod/PRZ6TSqvJKuZH8JMzRDJv41Gwlek15+vjWZJvWzSyeFc9LRaPfCdkO/hLq8P3PZ7muIll X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Aug 2016 19:43:40.1870 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: MWHPR12MB1453 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch adds support to detect and initialize IOMMU Guest vAPIC log (GALOG). By default, it also enable GALog interrupt to notify IOMMU driver when GA Log entry is created. Signed-off-by: Suravee Suthikulpanit --- drivers/iommu/amd_iommu_init.c | 112 +++++++++++++++++++++++++++++++++++++--- drivers/iommu/amd_iommu_types.h | 28 ++++++++++ 2 files changed, 133 insertions(+), 7 deletions(-) -- 1.9.1 diff --git a/drivers/iommu/amd_iommu_init.c b/drivers/iommu/amd_iommu_init.c index c17febb..156ab4b 100644 --- a/drivers/iommu/amd_iommu_init.c +++ b/drivers/iommu/amd_iommu_init.c @@ -84,6 +84,7 @@ #define ACPI_DEVFLAG_LINT1 0x80 #define ACPI_DEVFLAG_ATSDIS 0x10000000 +#define LOOP_TIMEOUT 100000 /* * ACPI table definitions * @@ -388,6 +389,10 @@ static void iommu_disable(struct amd_iommu *iommu) iommu_feature_disable(iommu, CONTROL_EVT_INT_EN); iommu_feature_disable(iommu, CONTROL_EVT_LOG_EN); + /* Disable IOMMU GA_LOG */ + iommu_feature_disable(iommu, CONTROL_GALOG_EN); + iommu_feature_disable(iommu, CONTROL_GAINT_EN); + /* Disable IOMMU hardware itself */ iommu_feature_disable(iommu, CONTROL_IOMMU_EN); } @@ -673,6 +678,99 @@ static void __init free_ppr_log(struct amd_iommu *iommu) free_pages((unsigned long)iommu->ppr_log, get_order(PPR_LOG_SIZE)); } +static void free_ga_log(struct amd_iommu *iommu) +{ +#ifdef CONFIG_IRQ_REMAP + if (iommu->ga_log) + free_pages((unsigned long)iommu->ga_log, + get_order(GA_LOG_SIZE)); + if (iommu->ga_log_tail) + free_pages((unsigned long)iommu->ga_log_tail, + get_order(8)); +#endif +} + +static int iommu_ga_log_enable(struct amd_iommu *iommu) +{ +#ifdef CONFIG_IRQ_REMAP + u32 status, i; + + if (!iommu->ga_log) + return -EINVAL; + + status = readl(iommu->mmio_base + MMIO_STATUS_OFFSET); + + /* Check if already running */ + if (status & (MMIO_STATUS_GALOG_RUN_MASK)) + return 0; + + iommu_feature_enable(iommu, CONTROL_GAINT_EN); + iommu_feature_enable(iommu, CONTROL_GALOG_EN); + + for (i = 0; i < LOOP_TIMEOUT; ++i) { + status = readl(iommu->mmio_base + MMIO_STATUS_OFFSET); + if (status & (MMIO_STATUS_GALOG_RUN_MASK)) + break; + } + + if (i >= LOOP_TIMEOUT) + return -EINVAL; +#endif /* CONFIG_IRQ_REMAP */ + return 0; +} + +#ifdef CONFIG_IRQ_REMAP +static int iommu_init_ga_log(struct amd_iommu *iommu) +{ + u64 entry; + + if (!AMD_IOMMU_GUEST_IR_VAPIC(amd_iommu_guest_ir)) + return 0; + + iommu->ga_log = (u8 *)__get_free_pages(GFP_KERNEL | __GFP_ZERO, + get_order(GA_LOG_SIZE)); + if (!iommu->ga_log) + goto err_out; + + iommu->ga_log_tail = (u8 *)__get_free_pages(GFP_KERNEL | __GFP_ZERO, + get_order(8)); + if (!iommu->ga_log_tail) + goto err_out; + + entry = (u64)virt_to_phys(iommu->ga_log) | GA_LOG_SIZE_512; + memcpy_toio(iommu->mmio_base + MMIO_GA_LOG_BASE_OFFSET, + &entry, sizeof(entry)); + entry = ((u64)virt_to_phys(iommu->ga_log) & 0xFFFFFFFFFFFFFULL) & ~7ULL; + memcpy_toio(iommu->mmio_base + MMIO_GA_LOG_TAIL_OFFSET, + &entry, sizeof(entry)); + writel(0x00, iommu->mmio_base + MMIO_GA_HEAD_OFFSET); + writel(0x00, iommu->mmio_base + MMIO_GA_TAIL_OFFSET); + + return 0; +err_out: + free_ga_log(iommu); + return -EINVAL; +} +#endif /* CONFIG_IRQ_REMAP */ + +static int iommu_init_ga(struct amd_iommu *iommu) +{ + int ret = 0; + +#ifdef CONFIG_IRQ_REMAP + /* Note: We have already checked GASup from IVRS table. + * Now, we need to make sure that GAMSup is set. + */ + if (AMD_IOMMU_GUEST_IR_VAPIC(amd_iommu_guest_ir) && + !iommu_feature(iommu, FEATURE_GAM_VAPIC)) + amd_iommu_guest_ir = AMD_IOMMU_GUEST_IR_LEGACY_GA; + + ret = iommu_init_ga_log(iommu); +#endif /* CONFIG_IRQ_REMAP */ + + return ret; +} + static void iommu_enable_gt(struct amd_iommu *iommu) { if (!iommu_feature(iommu, FEATURE_GT)) @@ -1146,6 +1244,7 @@ static void __init free_iommu_one(struct amd_iommu *iommu) free_command_buffer(iommu); free_event_buffer(iommu); free_ppr_log(iommu); + free_ga_log(iommu); iommu_unmap_mmio_space(iommu); } @@ -1438,6 +1537,7 @@ static int iommu_init_pci(struct amd_iommu *iommu) { int cap_ptr = iommu->cap_ptr; u32 range, misc, low, high; + int ret; iommu->dev = pci_get_bus_and_slot(PCI_BUS_NUM(iommu->devid), iommu->devid & 0xff); @@ -1494,13 +1594,9 @@ static int iommu_init_pci(struct amd_iommu *iommu) if (iommu_feature(iommu, FEATURE_PPR) && alloc_ppr_log(iommu)) return -ENOMEM; - /* Note: We have already checked GASup from IVRS table. - * Now, we need to make sure that GAMSup is set. - */ - if (AMD_IOMMU_GUEST_IR_VAPIC(amd_iommu_guest_ir) && - !iommu_feature(iommu, FEATURE_GAM_VAPIC)) - amd_iommu_guest_ir = AMD_IOMMU_GUEST_IR_LEGACY_GA; - + ret = iommu_init_ga(iommu); + if (ret) + return ret; if (iommu->cap & (1UL << IOMMU_CAP_NPCACHE)) amd_iommu_np_cache = true; @@ -1667,6 +1763,8 @@ enable_faults: if (iommu->ppr_log != NULL) iommu_feature_enable(iommu, CONTROL_PPFINT_EN); + iommu_ga_log_enable(iommu); + return 0; } diff --git a/drivers/iommu/amd_iommu_types.h b/drivers/iommu/amd_iommu_types.h index a591747..a3b6e22 100644 --- a/drivers/iommu/amd_iommu_types.h +++ b/drivers/iommu/amd_iommu_types.h @@ -70,6 +70,8 @@ #define MMIO_EXCL_LIMIT_OFFSET 0x0028 #define MMIO_EXT_FEATURES 0x0030 #define MMIO_PPR_LOG_OFFSET 0x0038 +#define MMIO_GA_LOG_BASE_OFFSET 0x00e0 +#define MMIO_GA_LOG_TAIL_OFFSET 0x00e8 #define MMIO_CMD_HEAD_OFFSET 0x2000 #define MMIO_CMD_TAIL_OFFSET 0x2008 #define MMIO_EVT_HEAD_OFFSET 0x2010 @@ -77,6 +79,8 @@ #define MMIO_STATUS_OFFSET 0x2020 #define MMIO_PPR_HEAD_OFFSET 0x2030 #define MMIO_PPR_TAIL_OFFSET 0x2038 +#define MMIO_GA_HEAD_OFFSET 0x2040 +#define MMIO_GA_TAIL_OFFSET 0x2048 #define MMIO_CNTR_CONF_OFFSET 0x4000 #define MMIO_CNTR_REG_OFFSET 0x40000 #define MMIO_REG_END_OFFSET 0x80000 @@ -112,6 +116,9 @@ #define MMIO_STATUS_EVT_INT_MASK (1 << 1) #define MMIO_STATUS_COM_WAIT_INT_MASK (1 << 2) #define MMIO_STATUS_PPR_INT_MASK (1 << 6) +#define MMIO_STATUS_GALOG_RUN_MASK (1 << 8) +#define MMIO_STATUS_GALOG_OVERFLOW_MASK (1 << 9) +#define MMIO_STATUS_GALOG_INT_MASK (1 << 10) /* event logging constants */ #define EVENT_ENTRY_SIZE 0x10 @@ -150,6 +157,8 @@ #define CONTROL_GT_EN 0x10ULL #define CONTROL_GA_EN 0x11ULL #define CONTROL_GAM_EN 0x19ULL +#define CONTROL_GALOG_EN 0x1CULL +#define CONTROL_GAINT_EN 0x1DULL #define CTRL_INV_TO_MASK (7 << CONTROL_INV_TIMEOUT) #define CTRL_INV_TO_NONE 0 @@ -228,6 +237,19 @@ #define PPR_REQ_FAULT 0x01 +/* Constants for GA Log handling */ +#define GA_LOG_ENTRIES 512 +#define GA_LOG_SIZE_SHIFT 56 +#define GA_LOG_SIZE_512 (0x8ULL << GA_LOG_SIZE_SHIFT) +#define GA_ENTRY_SIZE 8 +#define GA_LOG_SIZE (GA_ENTRY_SIZE * GA_LOG_ENTRIES) + +#define GA_TAG(x) (u32)(x & 0xffffffffULL) +#define GA_DEVID(x) (u16)(((x) >> 32) & 0xffffULL) +#define GA_REQ_TYPE(x) (((x) >> 60) & 0xfULL) + +#define GA_GUEST_NR 0x1 + #define PAGE_MODE_NONE 0x00 #define PAGE_MODE_1_LEVEL 0x01 #define PAGE_MODE_2_LEVEL 0x02 @@ -502,6 +524,12 @@ struct amd_iommu { /* Base of the PPR log, if present */ u8 *ppr_log; + /* Base of the GA log, if present */ + u8 *ga_log; + + /* Tail of the GA log, if present */ + u8 *ga_log_tail; + /* true if interrupts for this IOMMU are already enabled */ bool int_enabled;