1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26#include "vm_helper.h"
27#include "dc.h"
28
29void vm_helper_mark_vmid_used(struct vm_helper *vm_helper, unsigned int pos, uint8_t hubp_idx)
30{
31 struct vmid_usage vmids = vm_helper->hubp_vmid_usage[hubp_idx];
32
33 vmids.vmid_usage[0] = vmids.vmid_usage[1];
34 vmids.vmid_usage[1] = 1 << pos;
35}
36
37int dc_setup_system_context(struct dc *dc, struct dc_phy_addr_space_config *pa_config)
38{
39 int num_vmids = 0;
40
41
42 if (dc->hwss.init_sys_ctx) {
43 num_vmids = dc->hwss.init_sys_ctx(dc->hwseq, dc, pa_config);
44
45
46
47
48 memcpy(&dc->vm_pa_config, pa_config, sizeof(struct dc_phy_addr_space_config));
49 dc->vm_pa_config.valid = true;
50#if defined(CONFIG_DRM_AMD_DC_DCN)
51 dc_z10_save_init(dc);
52#endif
53 }
54
55 return num_vmids;
56}
57
58void dc_setup_vm_context(struct dc *dc, struct dc_virtual_addr_space_config *va_config, int vmid)
59{
60 dc->hwss.init_vm_ctx(dc->hwseq, dc, va_config, vmid);
61}
62
63int dc_get_vmid_use_vector(struct dc *dc)
64{
65 int i;
66 int in_use = 0;
67
68 for (i = 0; i < MAX_HUBP; i++)
69 in_use |= dc->vm_helper->hubp_vmid_usage[i].vmid_usage[0]
70 | dc->vm_helper->hubp_vmid_usage[i].vmid_usage[1];
71 return in_use;
72}
73
74void vm_helper_init(struct vm_helper *vm_helper, unsigned int num_vmid)
75{
76 vm_helper->num_vmid = num_vmid;
77
78 memset(vm_helper->hubp_vmid_usage, 0, sizeof(vm_helper->hubp_vmid_usage[0]) * MAX_HUBP);
79}
80