}
}
-struct page *snp_safe_alloc_page(void)
+struct page *__snp_safe_alloc_page(gfp_t gfp)
{
unsigned long pfn;
struct page *p;
if (!cc_platform_has(CC_ATTR_HOST_SEV_SNP))
- return alloc_page(GFP_KERNEL_ACCOUNT | __GFP_ZERO);
+ return alloc_page(gfp | __GFP_ZERO);
/*
* Allocate an SNP-safe page to workaround the SNP erratum where
* Allocate one extra page, choose a page which is not
* 2MB-aligned, and free the other.
*/
- p = alloc_pages(GFP_KERNEL_ACCOUNT | __GFP_ZERO, 1);
+ p = alloc_pages(gfp | __GFP_ZERO, 1);
if (!p)
return NULL;
int ret = -ENOMEM;
memset(sd, 0, sizeof(struct svm_cpu_data));
- sd->save_area = snp_safe_alloc_page();
+ sd->save_area = __snp_safe_alloc_page(GFP_KERNEL);
if (!sd->save_area)
return ret;
int sev_handle_vmgexit(struct kvm_vcpu *vcpu);
/* These symbols are used in common code and are stubbed below. */
-struct page *snp_safe_alloc_page(void);
+struct page *__snp_safe_alloc_page(gfp_t gfp);
+
+static inline struct page *snp_safe_alloc_page(void)
+{
+ return __snp_safe_alloc_page(GFP_KERNEL_ACCOUNT);
+}
+
void sev_free_vcpu(struct kvm_vcpu *vcpu);
void sev_vm_destroy(struct kvm *kvm);
void __init sev_set_cpu_caps(void);
int sev_dev_get_attr(u32 group, u64 attr, u64 *val);
extern unsigned int max_sev_asid;
#else
+static inline struct page *__snp_safe_alloc_page(gfp_t gfp)
+{
+ return alloc_page(gfp | __GFP_ZERO);
+}
+
static inline struct page *snp_safe_alloc_page(void)
{
- return alloc_page(GFP_KERNEL_ACCOUNT | __GFP_ZERO);
+ return __snp_safe_alloc_page(GFP_KERNEL_ACCOUNT);
}
static inline void sev_free_vcpu(struct kvm_vcpu *vcpu) {}