1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Copyright(c) 2020, Intel Corporation. All rights reserved.
4  */
5 
6 #ifndef __INTEL_PXP_H__
7 #define __INTEL_PXP_H__
8 
9 #include <linux/errno.h>
10 #include <linux/types.h>
11 
12 struct drm_i915_gem_object;
13 struct drm_i915_private;
14 struct intel_pxp;
15 
16 bool intel_pxp_is_supported(const struct intel_pxp *pxp);
17 bool intel_pxp_is_enabled(const struct intel_pxp *pxp);
18 bool intel_pxp_is_active(const struct intel_pxp *pxp);
19 
20 int intel_pxp_init(struct drm_i915_private *i915);
21 void intel_pxp_fini(struct drm_i915_private *i915);
22 
23 void intel_pxp_init_hw(struct intel_pxp *pxp);
24 void intel_pxp_fini_hw(struct intel_pxp *pxp);
25 
26 void intel_pxp_mark_termination_in_progress(struct intel_pxp *pxp);
27 
28 int intel_pxp_start(struct intel_pxp *pxp);
29 
30 int intel_pxp_key_check(struct intel_pxp *pxp,
31 			struct drm_i915_gem_object *obj,
32 			bool assign);
33 
34 void intel_pxp_invalidate(struct intel_pxp *pxp);
35 
36 #endif /* __INTEL_PXP_H__ */
37