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