1 /* SPDX-License-Identifier: MIT */
3 * Copyright © 2014-2019 Intel Corporation
9 #include "intel_uncore.h"
10 #include "intel_guc_fw.h"
11 #include "intel_guc_fwif.h"
12 #include "intel_guc_ct.h"
13 #include "intel_guc_log.h"
14 #include "intel_guc_reg.h"
15 #include "intel_uc_fw.h"
16 #include "i915_utils.h"
19 struct __guc_ads_blob
;
22 * Top level structure of GuC. It handles firmware loading and manages client
23 * pool. intel_guc owns a intel_guc_client to replace the legacy ExecList
27 struct intel_uc_fw fw
;
28 struct intel_guc_log log
;
29 struct intel_guc_ct ct
;
31 /* intel_guc_recv interrupt related state */
33 unsigned int msg_enabled_mask
;
37 void (*reset
)(struct intel_guc
*guc
);
38 void (*enable
)(struct intel_guc
*guc
);
39 void (*disable
)(struct intel_guc
*guc
);
42 bool submission_supported
;
44 struct i915_vma
*ads_vma
;
45 struct __guc_ads_blob
*ads_blob
;
47 struct i915_vma
*stage_desc_pool
;
48 void *stage_desc_pool_vaddr
;
50 struct i915_vma
*workqueue
;
51 void *workqueue_vaddr
;
54 struct i915_vma
*proc_desc
;
55 void *proc_desc_vaddr
;
57 /* Control params for fw initialization */
58 u32 params
[GUC_CTL_MAX_DWORDS
];
60 /* GuC's FW specific registers used in MMIO send */
64 enum forcewake_domains fw_domains
;
67 /* register used to send interrupts to the GuC FW */
68 i915_reg_t notify_reg
;
70 /* Store msg (e.g. log flush) that we see while CTBs are disabled */
73 /* To serialize the intel_guc_send actions */
74 struct mutex send_mutex
;
78 inline int intel_guc_send(struct intel_guc
*guc
, const u32
*action
, u32 len
)
80 return intel_guc_ct_send(&guc
->ct
, action
, len
, NULL
, 0);
84 intel_guc_send_and_receive(struct intel_guc
*guc
, const u32
*action
, u32 len
,
85 u32
*response_buf
, u32 response_buf_size
)
87 return intel_guc_ct_send(&guc
->ct
, action
, len
,
88 response_buf
, response_buf_size
);
91 static inline void intel_guc_to_host_event_handler(struct intel_guc
*guc
)
93 intel_guc_ct_event_handler(&guc
->ct
);
96 /* GuC addresses above GUC_GGTT_TOP also don't map through the GTT */
97 #define GUC_GGTT_TOP 0xFEE00000
100 * intel_guc_ggtt_offset() - Get and validate the GGTT offset of @vma
101 * @guc: intel_guc structure.
102 * @vma: i915 graphics virtual memory area.
104 * GuC does not allow any gfx GGTT address that falls into range
105 * [0, ggtt.pin_bias), which is reserved for Boot ROM, SRAM and WOPCM.
106 * Currently, in order to exclude [0, ggtt.pin_bias) address space from
107 * GGTT, all gfx objects used by GuC are allocated with intel_guc_allocate_vma()
108 * and pinned with PIN_OFFSET_BIAS along with the value of ggtt.pin_bias.
110 * Return: GGTT offset of the @vma.
112 static inline u32
intel_guc_ggtt_offset(struct intel_guc
*guc
,
113 struct i915_vma
*vma
)
115 u32 offset
= i915_ggtt_offset(vma
);
117 GEM_BUG_ON(offset
< i915_ggtt_pin_bias(vma
));
118 GEM_BUG_ON(range_overflows_t(u64
, offset
, vma
->size
, GUC_GGTT_TOP
));
123 void intel_guc_init_early(struct intel_guc
*guc
);
124 void intel_guc_init_send_regs(struct intel_guc
*guc
);
125 void intel_guc_write_params(struct intel_guc
*guc
);
126 int intel_guc_init(struct intel_guc
*guc
);
127 void intel_guc_fini(struct intel_guc
*guc
);
128 void intel_guc_notify(struct intel_guc
*guc
);
129 int intel_guc_send_mmio(struct intel_guc
*guc
, const u32
*action
, u32 len
,
130 u32
*response_buf
, u32 response_buf_size
);
131 int intel_guc_to_host_process_recv_msg(struct intel_guc
*guc
,
132 const u32
*payload
, u32 len
);
133 int intel_guc_sample_forcewake(struct intel_guc
*guc
);
134 int intel_guc_auth_huc(struct intel_guc
*guc
, u32 rsa_offset
);
135 int intel_guc_suspend(struct intel_guc
*guc
);
136 int intel_guc_resume(struct intel_guc
*guc
);
137 struct i915_vma
*intel_guc_allocate_vma(struct intel_guc
*guc
, u32 size
);
138 int intel_guc_allocate_and_map_vma(struct intel_guc
*guc
, u32 size
,
139 struct i915_vma
**out_vma
, void **out_vaddr
);
141 static inline bool intel_guc_is_supported(struct intel_guc
*guc
)
143 return intel_uc_fw_is_supported(&guc
->fw
);
146 static inline bool intel_guc_is_enabled(struct intel_guc
*guc
)
148 return intel_uc_fw_is_enabled(&guc
->fw
);
151 static inline bool intel_guc_is_running(struct intel_guc
*guc
)
153 return intel_uc_fw_is_running(&guc
->fw
);
156 static inline int intel_guc_sanitize(struct intel_guc
*guc
)
158 intel_uc_fw_sanitize(&guc
->fw
);
164 static inline bool intel_guc_is_submission_supported(struct intel_guc
*guc
)
166 return guc
->submission_supported
;
169 static inline void intel_guc_enable_msg(struct intel_guc
*guc
, u32 mask
)
171 spin_lock_irq(&guc
->irq_lock
);
172 guc
->msg_enabled_mask
|= mask
;
173 spin_unlock_irq(&guc
->irq_lock
);
176 static inline void intel_guc_disable_msg(struct intel_guc
*guc
, u32 mask
)
178 spin_lock_irq(&guc
->irq_lock
);
179 guc
->msg_enabled_mask
&= ~mask
;
180 spin_unlock_irq(&guc
->irq_lock
);
183 int intel_guc_reset_engine(struct intel_guc
*guc
,
184 struct intel_engine_cs
*engine
);