162306a36Sopenharmony_ci/* SPDX-License-Identifier: MIT */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright(c) 2020, Intel Corporation. All rights reserved.
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#ifndef __INTEL_PXP_H__
762306a36Sopenharmony_ci#define __INTEL_PXP_H__
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include <linux/errno.h>
1062306a36Sopenharmony_ci#include <linux/types.h>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cistruct drm_i915_gem_object;
1362306a36Sopenharmony_cistruct drm_i915_private;
1462306a36Sopenharmony_cistruct intel_pxp;
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_cibool intel_pxp_is_supported(const struct intel_pxp *pxp);
1762306a36Sopenharmony_cibool intel_pxp_is_enabled(const struct intel_pxp *pxp);
1862306a36Sopenharmony_cibool intel_pxp_is_active(const struct intel_pxp *pxp);
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ciint intel_pxp_init(struct drm_i915_private *i915);
2162306a36Sopenharmony_civoid intel_pxp_fini(struct drm_i915_private *i915);
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_civoid intel_pxp_init_hw(struct intel_pxp *pxp);
2462306a36Sopenharmony_civoid intel_pxp_fini_hw(struct intel_pxp *pxp);
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_civoid intel_pxp_mark_termination_in_progress(struct intel_pxp *pxp);
2762306a36Sopenharmony_civoid intel_pxp_tee_end_arb_fw_session(struct intel_pxp *pxp, u32 arb_session_id);
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ciint intel_pxp_get_readiness_status(struct intel_pxp *pxp);
3062306a36Sopenharmony_ciint intel_pxp_get_backend_timeout_ms(struct intel_pxp *pxp);
3162306a36Sopenharmony_ciint intel_pxp_start(struct intel_pxp *pxp);
3262306a36Sopenharmony_civoid intel_pxp_end(struct intel_pxp *pxp);
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ciint intel_pxp_key_check(struct intel_pxp *pxp,
3562306a36Sopenharmony_ci			struct drm_i915_gem_object *obj,
3662306a36Sopenharmony_ci			bool assign);
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_civoid intel_pxp_invalidate(struct intel_pxp *pxp);
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci#endif /* __INTEL_PXP_H__ */
41