Blame SOURCES/kexec-tools-2.0.15-makedumpfile-x86_64-Add-support-for-AMD-Secure-Memory-Encry.patch

cf4a81
Delivered-To: bhsharma@gapps.redhat.com
cf4a81
Received: by 2002:a2e:e0a:0:0:0:0:0 with SMTP id 10csp381404ljo;
cf4a81
        Fri, 21 Jun 2019 02:43:25 -0700 (PDT)
cf4a81
X-Google-Smtp-Source: APXvYqzT5Jnctz0U7KDu97glThU9nNU8uoBaTPDtgGoLDaTrBerwj871GlRx1br1kO3Xi9egk5Ga
cf4a81
X-Received: by 2002:a0c:d0fc:: with SMTP id b57mr43991751qvh.78.1561110205383;
cf4a81
        Fri, 21 Jun 2019 02:43:25 -0700 (PDT)
cf4a81
ARC-Seal: i=1; a=rsa-sha256; t=1561110205; cv=none;
cf4a81
        d=google.com; s=arc-20160816;
cf4a81
        b=UGnWY4xATAi/VC/zo6DWbisWbInCXQEb7saZdCpdFg6DjOXNGTGy8OoGOrKaF2an1F
cf4a81
         /30UqiXL5Yd3KF5eCKmMCuvQ+CUwUKDAUtewF1t4iGMe6Z3aIi4z6mZaDZELpIIeYSOh
cf4a81
         WO0qQC+gnyBlQuAbDBSo5NUprcZ8xMsCs0d5kZr3BVgGOXJtZgmIBVLV4yKHRjDW29Nn
cf4a81
         P/pelr5UUYaNW1C0ILMv60vk0Py4VM5oRTQ4otxgkw9soGxUjTsMEA0X49vOdVrfXa9P
cf4a81
         QZbvmXrMB22TNGHkWgPjAkHFxXakJEDq18fwX0dTuxTbx9vlFyaaBdv+CQ+yqfixS70j
cf4a81
         +93w==
cf4a81
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816;
cf4a81
        h=message-id:date:subject:cc:to:from:delivered-to;
cf4a81
        bh=0Hr1bq++ZN4c9flsD+ZIcevaW3VxsiFEPs30XoiYUL4=;
cf4a81
        b=paFXhKPPrG7vRaUqzedY45uKY678PbjOiGQSyfzC6DSZFuZ4NepnUyEGwVmd+b0Scc
cf4a81
         O6bzSXYRuXGALKasZkfkEeJLyJUldvlZcmcnGO64gmKGyEq8wmrGGG3J66y2M9UC22NI
cf4a81
         PQ6u0bmWizODueS2cKkHJ+MsmkJ91523n359wDPTb5hyt25mZ/Ax9s7SfHzshVHjdvLx
cf4a81
         Ugmod/BpgtWaxDUKoIdM4a6hM9UOLcyla/XE5HlJlijZHVa0rmQLvKqHBpdWD6FgacTJ
cf4a81
         BF6xPn0fDSZqWz4LwElIuzRiF405Hp8cq4LxGvTZNVm4F9WK+QurgUq/Um/LeJWZ0fgF
cf4a81
         kfTA==
cf4a81
ARC-Authentication-Results: i=1; mx.google.com;
cf4a81
       spf=pass (google.com: domain gapps.redhat.com configured 209.132.183.28 as internal address) smtp.mailfrom=lijiang@redhat.com
cf4a81
Return-Path: <lijiang@redhat.com>
cf4a81
Received: from mx1.redhat.com (mx1.redhat.com. [209.132.183.28])
cf4a81
        by mx.google.com with ESMTPS id u34si1484288qtj.352.2019.06.21.02.43.25
cf4a81
        for <bhsharma@gapps.redhat.com>
cf4a81
        (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128);
cf4a81
        Fri, 21 Jun 2019 02:43:25 -0700 (PDT)
cf4a81
Received-SPF: pass (google.com: domain gapps.redhat.com configured 209.132.183.28 as internal address)
cf4a81
Authentication-Results: mx.google.com;
cf4a81
       spf=pass (google.com: domain gapps.redhat.com configured 209.132.183.28 as internal address) smtp.mailfrom=lijiang@redhat.com
cf4a81
Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14])
cf4a81
	(using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits))
cf4a81
	(No client certificate requested)
cf4a81
	by mx1.redhat.com (Postfix) with ESMTPS id 8C7DB3004425
cf4a81
	for <bhsharma@gapps.redhat.com>; Fri, 21 Jun 2019 09:43:24 +0000 (UTC)
cf4a81
Received: by smtp.corp.redhat.com (Postfix)
cf4a81
	id 8712D5D9E5; Fri, 21 Jun 2019 09:43:24 +0000 (UTC)
cf4a81
Delivered-To: bhsharma@redhat.com
cf4a81
Received: from localhost.localdomain.com (ovpn-12-71.pek2.redhat.com [10.72.12.71])
cf4a81
	by smtp.corp.redhat.com (Postfix) with ESMTP id BF70C5D9D2;
cf4a81
	Fri, 21 Jun 2019 09:43:17 +0000 (UTC)
cf4a81
From: Lianbo Jiang <lijiang@redhat.com>
cf4a81
To: bhsharma@redhat.com
cf4a81
Cc: lijiang@redhat.com
cf4a81
Subject: [PATCH] x86_64: Add support for AMD Secure Memory Encryption
cf4a81
Date: Fri, 21 Jun 2019 17:43:12 +0800
cf4a81
Message-Id: <20190621094312.3180-1-lijiang@redhat.com>
cf4a81
X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14
cf4a81
X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.49]); Fri, 21 Jun 2019 09:43:24 +0000 (UTC)
cf4a81
cf4a81
On AMD machine with Secure Memory Encryption (SME) feature, if SME is
cf4a81
enabled, page tables contain a specific attribute bit (C-bit) in their
cf4a81
entries to indicate whether a page is encrypted or unencrypted.
cf4a81
cf4a81
So get NUMBER(sme_mask) from vmcoreinfo, which stores the value of
cf4a81
the C-bit position, and drop it to obtain the true physical address.
cf4a81
cf4a81
Signed-off-by: Lianbo Jiang <lijiang@redhat.com>
cf4a81
---
cf4a81
 arch/x86_64.c  | 28 +++++++++++++++++++---------
cf4a81
 makedumpfile.c |  4 ++++
cf4a81
 makedumpfile.h |  1 +
cf4a81
 3 files changed, 24 insertions(+), 9 deletions(-)
cf4a81
cf4a81
diff --git a/makedumpfile-1.6.2/arch/x86_64.c b/makedumpfile-1.6.2/arch/x86_64.c
cf4a81
index 33621f1f259c..d897e35f062e 100644
cf4a81
--- a/makedumpfile-1.6.2/arch/x86_64.c
cf4a81
+++ b/makedumpfile-1.6.2/arch/x86_64.c
cf4a81
@@ -259,6 +259,7 @@ __vtop4_x86_64(unsigned long vaddr, unsigned long pagetable)
cf4a81
 {
cf4a81
 	unsigned long page_dir, pml4, pgd_paddr, pgd_pte, pmd_paddr, pmd_pte;
cf4a81
 	unsigned long pte_paddr, pte;
cf4a81
+	unsigned long entry_mask = ENTRY_MASK;
cf4a81
 
cf4a81
 	/*
cf4a81
 	 * Get PGD.
cf4a81
@@ -269,6 +270,10 @@ __vtop4_x86_64(unsigned long vaddr, unsigned long pagetable)
cf4a81
 		if (page_dir == NOT_PADDR)
cf4a81
 			return NOT_PADDR;
cf4a81
 	}
cf4a81
+
cf4a81
+	if (NUMBER(sme_mask) != NOT_FOUND_NUMBER)
cf4a81
+		entry_mask &= ~(NUMBER(sme_mask));
cf4a81
+
cf4a81
 	page_dir += pml4_index(vaddr) * sizeof(unsigned long);
cf4a81
 	if (!readmem(PADDR, page_dir, &pml4, sizeof pml4)) {
cf4a81
 		ERRMSG("Can't get pml4 (page_dir:%lx).\n", page_dir);
cf4a81
@@ -285,7 +290,7 @@ __vtop4_x86_64(unsigned long vaddr, unsigned long pagetable)
cf4a81
 	/*
cf4a81
 	 * Get PUD.
cf4a81
 	 */
cf4a81
-	pgd_paddr  = pml4 & ENTRY_MASK;
cf4a81
+	pgd_paddr  = pml4 & entry_mask;
cf4a81
 	pgd_paddr += pgd_index(vaddr) * sizeof(unsigned long);
cf4a81
 	if (!readmem(PADDR, pgd_paddr, &pgd_pte, sizeof pgd_pte)) {
cf4a81
 		ERRMSG("Can't get pgd_pte (pgd_paddr:%lx).\n", pgd_paddr);
cf4a81
@@ -299,13 +304,13 @@ __vtop4_x86_64(unsigned long vaddr, unsigned long pagetable)
cf4a81
 		return NOT_PADDR;
cf4a81
 	}
cf4a81
 	if (pgd_pte & _PAGE_PSE)	/* 1GB pages */
cf4a81
-		return (pgd_pte & ENTRY_MASK & PGDIR_MASK) +
cf4a81
+		return (pgd_pte & entry_mask & PGDIR_MASK) +
cf4a81
 			(vaddr & ~PGDIR_MASK);
cf4a81
 
cf4a81
 	/*
cf4a81
 	 * Get PMD.
cf4a81
 	 */
cf4a81
-	pmd_paddr  = pgd_pte & ENTRY_MASK;
cf4a81
+	pmd_paddr  = pgd_pte & entry_mask;
cf4a81
 	pmd_paddr += pmd_index(vaddr) * sizeof(unsigned long);
cf4a81
 	if (!readmem(PADDR, pmd_paddr, &pmd_pte, sizeof pmd_pte)) {
cf4a81
 		ERRMSG("Can't get pmd_pte (pmd_paddr:%lx).\n", pmd_paddr);
cf4a81
@@ -319,13 +324,13 @@ __vtop4_x86_64(unsigned long vaddr, unsigned long pagetable)
cf4a81
 		return NOT_PADDR;
cf4a81
 	}
cf4a81
 	if (pmd_pte & _PAGE_PSE)	/* 2MB pages */
cf4a81
-		return (pmd_pte & ENTRY_MASK & PMD_MASK) +
cf4a81
+		return (pmd_pte & entry_mask & PMD_MASK) +
cf4a81
 			(vaddr & ~PMD_MASK);
cf4a81
 
cf4a81
 	/*
cf4a81
 	 * Get PTE.
cf4a81
 	 */
cf4a81
-	pte_paddr  = pmd_pte & ENTRY_MASK;
cf4a81
+	pte_paddr  = pmd_pte & entry_mask;
cf4a81
 	pte_paddr += pte_index(vaddr) * sizeof(unsigned long);
cf4a81
 	if (!readmem(PADDR, pte_paddr, &pte, sizeof pte)) {
cf4a81
 		ERRMSG("Can't get pte (pte_paddr:%lx).\n", pte_paddr);
cf4a81
@@ -338,7 +343,7 @@ __vtop4_x86_64(unsigned long vaddr, unsigned long pagetable)
cf4a81
 		ERRMSG("Can't get a valid pte.\n");
cf4a81
 		return NOT_PADDR;
cf4a81
 	}
cf4a81
-	return (pte & ENTRY_MASK) + PAGEOFFSET(vaddr);
cf4a81
+	return (pte & entry_mask) + PAGEOFFSET(vaddr);
cf4a81
 }
cf4a81
 
cf4a81
 unsigned long long
cf4a81
@@ -553,6 +558,7 @@ find_vmemmap_x86_64()
cf4a81
 	unsigned long pmd, tpfn;
cf4a81
 	unsigned long pvaddr = 0;
cf4a81
 	unsigned long data_addr = 0, last_data_addr = 0, start_data_addr = 0;
cf4a81
+	unsigned long pmask = PMASK;
cf4a81
 	/*
cf4a81
 	 * data_addr is the paddr of the page holding the page structs.
cf4a81
 	 * We keep lists of contiguous pages and the pfn's that their
cf4a81
@@ -569,6 +575,10 @@ find_vmemmap_x86_64()
cf4a81
 		ERRMSG("init_level4_pgt not found\n");
cf4a81
 		return FAILED;
cf4a81
 	}
cf4a81
+
cf4a81
+	if (NUMBER(sme_mask) != NOT_FOUND_NUMBER)
cf4a81
+		pmask &= ~(NUMBER(sme_mask));
cf4a81
+
cf4a81
 	pagestructsize = size_table.page;
cf4a81
 	hugepagesize = PTRS_PER_PMD * info->page_size;
cf4a81
 	vaddr_base = info->vmemmap_start;
cf4a81
@@ -597,7 +607,7 @@ find_vmemmap_x86_64()
cf4a81
 			return FAILED;
cf4a81
 		}
cf4a81
 		/* mask the pgd entry for the address of the pud page */
cf4a81
-		pud_addr &= PMASK;
cf4a81
+		pud_addr &= pmask;
cf4a81
 		if (pud_addr == 0)
cf4a81
 			  continue;
cf4a81
 		/* read the entire pud page */
cf4a81
@@ -610,7 +620,7 @@ find_vmemmap_x86_64()
cf4a81
 		/* pudp points to an entry in the pud page */
cf4a81
 		for (pudp = (unsigned long *)pud_page, pudindex = 0;
cf4a81
 					pudindex < PTRS_PER_PUD; pudindex++, pudp++) {
cf4a81
-			pmd_addr = *pudp & PMASK;
cf4a81
+			pmd_addr = *pudp & pmask;
cf4a81
 			/* read the entire pmd page */
cf4a81
 			if (pmd_addr == 0)
cf4a81
 				continue;
cf4a81
@@ -652,7 +662,7 @@ find_vmemmap_x86_64()
cf4a81
 				 * - we discontiguous page is a string of valids
cf4a81
 				 */
cf4a81
 				if (pmd) {
cf4a81
-					data_addr = (pmd & PMASK);
cf4a81
+					data_addr = (pmd & pmask);
cf4a81
 					if (start_range) {
cf4a81
 						/* first-time kludge */
cf4a81
 						start_data_addr = data_addr;
cf4a81
diff --git a/makedumpfile-1.6.2/makedumpfile.c b/makedumpfile-1.6.2/makedumpfile.c
cf4a81
index c9634cd42858..ed097c7e597a 100644
cf4a81
--- a/makedumpfile-1.6.2/makedumpfile.c
cf4a81
+++ b/makedumpfile-1.6.2/makedumpfile.c
cf4a81
@@ -960,6 +960,8 @@ next_page:
cf4a81
 	read_size = MIN(info->page_size - PAGEOFFSET(paddr), size);
cf4a81
 
cf4a81
 	pgaddr = PAGEBASE(paddr);
cf4a81
+	if (NUMBER(sme_mask) != NOT_FOUND_NUMBER)
cf4a81
+		pgaddr = pgaddr & ~(NUMBER(sme_mask));
cf4a81
 	pgbuf = cache_search(pgaddr, read_size);
cf4a81
 	if (!pgbuf) {
cf4a81
 		++cache_miss;
cf4a81
@@ -2248,6 +2250,7 @@ write_vmcoreinfo_data(void)
cf4a81
 
cf4a81
 	WRITE_NUMBER("NR_FREE_PAGES", NR_FREE_PAGES);
cf4a81
 	WRITE_NUMBER("N_ONLINE", N_ONLINE);
cf4a81
+	WRITE_NUMBER("sme_mask", sme_mask);
cf4a81
 
cf4a81
 	WRITE_NUMBER("PG_lru", PG_lru);
cf4a81
 	WRITE_NUMBER("PG_private", PG_private);
cf4a81
@@ -2642,6 +2645,7 @@ read_vmcoreinfo(void)
cf4a81
 
cf4a81
 	READ_NUMBER("NR_FREE_PAGES", NR_FREE_PAGES);
cf4a81
 	READ_NUMBER("N_ONLINE", N_ONLINE);
cf4a81
+	READ_NUMBER("sme_mask", sme_mask);
cf4a81
 
cf4a81
 	READ_NUMBER("PG_lru", PG_lru);
cf4a81
 	READ_NUMBER("PG_private", PG_private);
cf4a81
diff --git a/makedumpfile-1.6.2/makedumpfile.h b/makedumpfile-1.6.2/makedumpfile.h
cf4a81
index 5f7a1dcf3b2f..bc3a4555132a 100644
cf4a81
--- a/makedumpfile-1.6.2/makedumpfile.h
cf4a81
+++ b/makedumpfile-1.6.2/makedumpfile.h
cf4a81
@@ -1860,6 +1860,7 @@ struct array_table {
cf4a81
 struct number_table {
cf4a81
 	long	NR_FREE_PAGES;
cf4a81
 	long	N_ONLINE;
cf4a81
+	long    sme_mask;
cf4a81
 
cf4a81
 	/*
cf4a81
  	* Page flags
cf4a81
-- 
cf4a81
2.17.1
cf4a81