162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Ultravisor definitions
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright 2019, IBM Corporation.
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci#ifndef _ASM_POWERPC_ULTRAVISOR_H
962306a36Sopenharmony_ci#define _ASM_POWERPC_ULTRAVISOR_H
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <asm/asm-prototypes.h>
1262306a36Sopenharmony_ci#include <asm/ultravisor-api.h>
1362306a36Sopenharmony_ci#include <asm/firmware.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ciint early_init_dt_scan_ultravisor(unsigned long node, const char *uname,
1662306a36Sopenharmony_ci				  int depth, void *data);
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci/*
1962306a36Sopenharmony_ci * In ultravisor enabled systems, PTCR becomes ultravisor privileged only for
2062306a36Sopenharmony_ci * writing and an attempt to write to it will cause a Hypervisor Emulation
2162306a36Sopenharmony_ci * Assistance interrupt.
2262306a36Sopenharmony_ci */
2362306a36Sopenharmony_cistatic inline void set_ptcr_when_no_uv(u64 val)
2462306a36Sopenharmony_ci{
2562306a36Sopenharmony_ci	if (!firmware_has_feature(FW_FEATURE_ULTRAVISOR))
2662306a36Sopenharmony_ci		mtspr(SPRN_PTCR, val);
2762306a36Sopenharmony_ci}
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_cistatic inline int uv_register_pate(u64 lpid, u64 dw0, u64 dw1)
3062306a36Sopenharmony_ci{
3162306a36Sopenharmony_ci	return ucall_norets(UV_WRITE_PATE, lpid, dw0, dw1);
3262306a36Sopenharmony_ci}
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_cistatic inline int uv_share_page(u64 pfn, u64 npages)
3562306a36Sopenharmony_ci{
3662306a36Sopenharmony_ci	return ucall_norets(UV_SHARE_PAGE, pfn, npages);
3762306a36Sopenharmony_ci}
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_cistatic inline int uv_unshare_page(u64 pfn, u64 npages)
4062306a36Sopenharmony_ci{
4162306a36Sopenharmony_ci	return ucall_norets(UV_UNSHARE_PAGE, pfn, npages);
4262306a36Sopenharmony_ci}
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_cistatic inline int uv_unshare_all_pages(void)
4562306a36Sopenharmony_ci{
4662306a36Sopenharmony_ci	return ucall_norets(UV_UNSHARE_ALL_PAGES);
4762306a36Sopenharmony_ci}
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_cistatic inline int uv_page_in(u64 lpid, u64 src_ra, u64 dst_gpa, u64 flags,
5062306a36Sopenharmony_ci			     u64 page_shift)
5162306a36Sopenharmony_ci{
5262306a36Sopenharmony_ci	return ucall_norets(UV_PAGE_IN, lpid, src_ra, dst_gpa, flags,
5362306a36Sopenharmony_ci			    page_shift);
5462306a36Sopenharmony_ci}
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cistatic inline int uv_page_out(u64 lpid, u64 dst_ra, u64 src_gpa, u64 flags,
5762306a36Sopenharmony_ci			      u64 page_shift)
5862306a36Sopenharmony_ci{
5962306a36Sopenharmony_ci	return ucall_norets(UV_PAGE_OUT, lpid, dst_ra, src_gpa, flags,
6062306a36Sopenharmony_ci			    page_shift);
6162306a36Sopenharmony_ci}
6262306a36Sopenharmony_ci
6362306a36Sopenharmony_cistatic inline int uv_register_mem_slot(u64 lpid, u64 start_gpa, u64 size,
6462306a36Sopenharmony_ci				       u64 flags, u64 slotid)
6562306a36Sopenharmony_ci{
6662306a36Sopenharmony_ci	return ucall_norets(UV_REGISTER_MEM_SLOT, lpid, start_gpa,
6762306a36Sopenharmony_ci			    size, flags, slotid);
6862306a36Sopenharmony_ci}
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_cistatic inline int uv_unregister_mem_slot(u64 lpid, u64 slotid)
7162306a36Sopenharmony_ci{
7262306a36Sopenharmony_ci	return ucall_norets(UV_UNREGISTER_MEM_SLOT, lpid, slotid);
7362306a36Sopenharmony_ci}
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_cistatic inline int uv_page_inval(u64 lpid, u64 gpa, u64 page_shift)
7662306a36Sopenharmony_ci{
7762306a36Sopenharmony_ci	return ucall_norets(UV_PAGE_INVAL, lpid, gpa, page_shift);
7862306a36Sopenharmony_ci}
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_cistatic inline int uv_svm_terminate(u64 lpid)
8162306a36Sopenharmony_ci{
8262306a36Sopenharmony_ci	return ucall_norets(UV_SVM_TERMINATE, lpid);
8362306a36Sopenharmony_ci}
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ci#endif	/* _ASM_POWERPC_ULTRAVISOR_H */
86