-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
x86/sev: Add an x86 version of cc_platform_has()
commit aa5a461 upstream. Introduce an x86 version of the cc_platform_has() function. This will be used to replace vendor specific calls like sme_active(), sev_active(), etc. Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com> Signed-off-by: Borislav Petkov <bp@suse.de> Link: https://lkml.kernel.org/r/20210928191009.32551-4-bp@alien8.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
- Loading branch information
Tom Lendacky
authored and
Greg Kroah-Hartman
committed
Nov 18, 2021
1 parent
74ba917
commit fc25889
Showing
5 changed files
with
78 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
// SPDX-License-Identifier: GPL-2.0-only | ||
/* | ||
* Confidential Computing Platform Capability checks | ||
* | ||
* Copyright (C) 2021 Advanced Micro Devices, Inc. | ||
* | ||
* Author: Tom Lendacky <thomas.lendacky@amd.com> | ||
*/ | ||
|
||
#include <linux/export.h> | ||
#include <linux/cc_platform.h> | ||
#include <linux/mem_encrypt.h> | ||
|
||
#include <asm/processor.h> | ||
|
||
static bool __maybe_unused intel_cc_platform_has(enum cc_attr attr) | ||
{ | ||
#ifdef CONFIG_INTEL_TDX_GUEST | ||
return false; | ||
#else | ||
return false; | ||
#endif | ||
} | ||
|
||
/* | ||
* SME and SEV are very similar but they are not the same, so there are | ||
* times that the kernel will need to distinguish between SME and SEV. The | ||
* cc_platform_has() function is used for this. When a distinction isn't | ||
* needed, the CC_ATTR_MEM_ENCRYPT attribute can be used. | ||
* | ||
* The trampoline code is a good example for this requirement. Before | ||
* paging is activated, SME will access all memory as decrypted, but SEV | ||
* will access all memory as encrypted. So, when APs are being brought | ||
* up under SME the trampoline area cannot be encrypted, whereas under SEV | ||
* the trampoline area must be encrypted. | ||
*/ | ||
static bool amd_cc_platform_has(enum cc_attr attr) | ||
{ | ||
#ifdef CONFIG_AMD_MEM_ENCRYPT | ||
switch (attr) { | ||
case CC_ATTR_MEM_ENCRYPT: | ||
return sme_me_mask; | ||
|
||
case CC_ATTR_HOST_MEM_ENCRYPT: | ||
return sme_me_mask && !(sev_status & MSR_AMD64_SEV_ENABLED); | ||
|
||
case CC_ATTR_GUEST_MEM_ENCRYPT: | ||
return sev_status & MSR_AMD64_SEV_ENABLED; | ||
|
||
case CC_ATTR_GUEST_STATE_ENCRYPT: | ||
return sev_status & MSR_AMD64_SEV_ES_ENABLED; | ||
|
||
default: | ||
return false; | ||
} | ||
#else | ||
return false; | ||
#endif | ||
} | ||
|
||
|
||
bool cc_platform_has(enum cc_attr attr) | ||
{ | ||
if (sme_me_mask) | ||
return amd_cc_platform_has(attr); | ||
|
||
return false; | ||
} | ||
EXPORT_SYMBOL_GPL(cc_platform_has); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters