提交 3e3f6e1a 编写于 作者: O Oded Gabbay

drm/amdkfd: make the sdma vm init to be asic specific

Signed-off-by: NOded Gabbay <oded.gabbay@gmail.com>
Reviewed-by: NAlex Deucher <alexander.deucher@amd.com>
上级 d42af779
...@@ -614,19 +614,6 @@ static void deallocate_sdma_queue(struct device_queue_manager *dqm, ...@@ -614,19 +614,6 @@ static void deallocate_sdma_queue(struct device_queue_manager *dqm,
set_bit(sdma_queue_id, (unsigned long *)&dqm->sdma_bitmap); set_bit(sdma_queue_id, (unsigned long *)&dqm->sdma_bitmap);
} }
static void init_sdma_vm(struct device_queue_manager *dqm, struct queue *q,
struct qcm_process_device *qpd)
{
uint32_t value = SDMA_ATC;
if (q->process->is_32bit_user_mode)
value |= SDMA_VA_PTR32 | get_sh_mem_bases_32(qpd_to_pdd(qpd));
else
value |= SDMA_VA_SHARED_BASE(get_sh_mem_bases_nybble_64(
qpd_to_pdd(qpd)));
q->properties.sdma_vm_addr = value;
}
static int create_sdma_queue_nocpsch(struct device_queue_manager *dqm, static int create_sdma_queue_nocpsch(struct device_queue_manager *dqm,
struct queue *q, struct queue *q,
struct qcm_process_device *qpd) struct qcm_process_device *qpd)
...@@ -649,7 +636,7 @@ static int create_sdma_queue_nocpsch(struct device_queue_manager *dqm, ...@@ -649,7 +636,7 @@ static int create_sdma_queue_nocpsch(struct device_queue_manager *dqm,
pr_debug(" sdma queue id: %d\n", q->properties.sdma_queue_id); pr_debug(" sdma queue id: %d\n", q->properties.sdma_queue_id);
pr_debug(" sdma engine id: %d\n", q->properties.sdma_engine_id); pr_debug(" sdma engine id: %d\n", q->properties.sdma_engine_id);
init_sdma_vm(dqm, q, qpd); dqm->ops_asic_specific.init_sdma_vm(dqm, q, qpd);
retval = mqd->init_mqd(mqd, &q->mqd, &q->mqd_mem_obj, retval = mqd->init_mqd(mqd, &q->mqd, &q->mqd_mem_obj,
&q->gart_mqd_addr, &q->properties); &q->gart_mqd_addr, &q->properties);
if (retval != 0) { if (retval != 0) {
......
...@@ -130,6 +130,9 @@ struct device_queue_manager_asic_ops { ...@@ -130,6 +130,9 @@ struct device_queue_manager_asic_ops {
enum cache_policy alternate_policy, enum cache_policy alternate_policy,
void __user *alternate_aperture_base, void __user *alternate_aperture_base,
uint64_t alternate_aperture_size); uint64_t alternate_aperture_size);
void (*init_sdma_vm)(struct device_queue_manager *dqm,
struct queue *q,
struct qcm_process_device *qpd);
}; };
/** /**
......
...@@ -33,12 +33,15 @@ static bool set_cache_memory_policy_cik(struct device_queue_manager *dqm, ...@@ -33,12 +33,15 @@ static bool set_cache_memory_policy_cik(struct device_queue_manager *dqm,
static int register_process_cik(struct device_queue_manager *dqm, static int register_process_cik(struct device_queue_manager *dqm,
struct qcm_process_device *qpd); struct qcm_process_device *qpd);
static int initialize_cpsch_cik(struct device_queue_manager *dqm); static int initialize_cpsch_cik(struct device_queue_manager *dqm);
static void init_sdma_vm(struct device_queue_manager *dqm, struct queue *q,
struct qcm_process_device *qpd);
void device_queue_manager_init_cik(struct device_queue_manager_asic_ops *ops) void device_queue_manager_init_cik(struct device_queue_manager_asic_ops *ops)
{ {
ops->set_cache_memory_policy = set_cache_memory_policy_cik; ops->set_cache_memory_policy = set_cache_memory_policy_cik;
ops->register_process = register_process_cik; ops->register_process = register_process_cik;
ops->initialize = initialize_cpsch_cik; ops->initialize = initialize_cpsch_cik;
ops->init_sdma_vm = init_sdma_vm;
} }
static uint32_t compute_sh_mem_bases_64bit(unsigned int top_address_nybble) static uint32_t compute_sh_mem_bases_64bit(unsigned int top_address_nybble)
...@@ -129,6 +132,19 @@ static int register_process_cik(struct device_queue_manager *dqm, ...@@ -129,6 +132,19 @@ static int register_process_cik(struct device_queue_manager *dqm,
return 0; return 0;
} }
static void init_sdma_vm(struct device_queue_manager *dqm, struct queue *q,
struct qcm_process_device *qpd)
{
uint32_t value = SDMA_ATC;
if (q->process->is_32bit_user_mode)
value |= SDMA_VA_PTR32 | get_sh_mem_bases_32(qpd_to_pdd(qpd));
else
value |= SDMA_VA_SHARED_BASE(get_sh_mem_bases_nybble_64(
qpd_to_pdd(qpd)));
q->properties.sdma_vm_addr = value;
}
static int initialize_cpsch_cik(struct device_queue_manager *dqm) static int initialize_cpsch_cik(struct device_queue_manager *dqm)
{ {
return init_pipelines(dqm, get_pipes_num(dqm), get_first_pipe(dqm)); return init_pipelines(dqm, get_pipes_num(dqm), get_first_pipe(dqm));
......
...@@ -32,6 +32,8 @@ static bool set_cache_memory_policy_vi(struct device_queue_manager *dqm, ...@@ -32,6 +32,8 @@ static bool set_cache_memory_policy_vi(struct device_queue_manager *dqm,
static int register_process_vi(struct device_queue_manager *dqm, static int register_process_vi(struct device_queue_manager *dqm,
struct qcm_process_device *qpd); struct qcm_process_device *qpd);
static int initialize_cpsch_vi(struct device_queue_manager *dqm); static int initialize_cpsch_vi(struct device_queue_manager *dqm);
static void init_sdma_vm(struct device_queue_manager *dqm, struct queue *q,
struct qcm_process_device *qpd);
void device_queue_manager_init_vi(struct device_queue_manager_asic_ops *ops) void device_queue_manager_init_vi(struct device_queue_manager_asic_ops *ops)
{ {
...@@ -40,6 +42,7 @@ void device_queue_manager_init_vi(struct device_queue_manager_asic_ops *ops) ...@@ -40,6 +42,7 @@ void device_queue_manager_init_vi(struct device_queue_manager_asic_ops *ops)
ops->set_cache_memory_policy = set_cache_memory_policy_vi; ops->set_cache_memory_policy = set_cache_memory_policy_vi;
ops->register_process = register_process_vi; ops->register_process = register_process_vi;
ops->initialize = initialize_cpsch_vi; ops->initialize = initialize_cpsch_vi;
ops->init_sdma_vm = init_sdma_vm;
} }
static bool set_cache_memory_policy_vi(struct device_queue_manager *dqm, static bool set_cache_memory_policy_vi(struct device_queue_manager *dqm,
...@@ -58,6 +61,11 @@ static int register_process_vi(struct device_queue_manager *dqm, ...@@ -58,6 +61,11 @@ static int register_process_vi(struct device_queue_manager *dqm,
return -1; return -1;
} }
static void init_sdma_vm(struct device_queue_manager *dqm, struct queue *q,
struct qcm_process_device *qpd)
{
}
static int initialize_cpsch_vi(struct device_queue_manager *dqm) static int initialize_cpsch_vi(struct device_queue_manager *dqm)
{ {
return 0; return 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册