summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/nvgpu/gp10b
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/nvgpu/gp10b')
-rw-r--r--drivers/gpu/nvgpu/gp10b/hal_gp10b.c5
-rw-r--r--drivers/gpu/nvgpu/gp10b/pmu_gp10b.c39
-rw-r--r--drivers/gpu/nvgpu/gp10b/pmu_gp10b.h3
3 files changed, 5 insertions, 42 deletions
diff --git a/drivers/gpu/nvgpu/gp10b/hal_gp10b.c b/drivers/gpu/nvgpu/gp10b/hal_gp10b.c
index 759d271e..740cb8b7 100644
--- a/drivers/gpu/nvgpu/gp10b/hal_gp10b.c
+++ b/drivers/gpu/nvgpu/gp10b/hal_gp10b.c
@@ -794,7 +794,8 @@ int gp10b_init_hal(struct gk20a *g)
794 gm20b_flcn_populate_bl_dmem_desc, 794 gm20b_flcn_populate_bl_dmem_desc,
795 gops->pmu.update_lspmu_cmdline_args = 795 gops->pmu.update_lspmu_cmdline_args =
796 gm20b_update_lspmu_cmdline_args; 796 gm20b_update_lspmu_cmdline_args;
797 gops->pmu.setup_apertures = gm20b_setup_apertures; 797 gops->pmu.setup_apertures = gm20b_pmu_setup_apertures;
798 gops->pmu.secured_pmu_start = gm20b_secured_pmu_start;
798 799
799 gops->pmu.init_wpr_region = gm20b_pmu_init_acr; 800 gops->pmu.init_wpr_region = gm20b_pmu_init_acr;
800 gops->pmu.load_lsfalcon_ucode = gp10b_load_falcon_ucode; 801 gops->pmu.load_lsfalcon_ucode = gp10b_load_falcon_ucode;
@@ -806,6 +807,8 @@ int gp10b_init_hal(struct gk20a *g)
806 /* Inherit from gk20a */ 807 /* Inherit from gk20a */
807 gops->pmu.is_pmu_supported = gk20a_is_pmu_supported, 808 gops->pmu.is_pmu_supported = gk20a_is_pmu_supported,
808 gops->pmu.prepare_ucode = nvgpu_pmu_prepare_ns_ucode_blob, 809 gops->pmu.prepare_ucode = nvgpu_pmu_prepare_ns_ucode_blob,
810 gops->pmu.pmu_setup_hw_and_bootstrap =
811 gm20b_ns_pmu_setup_hw_and_bootstrap;
809 gops->pmu.pmu_nsbootstrap = pmu_bootstrap, 812 gops->pmu.pmu_nsbootstrap = pmu_bootstrap,
810 813
811 gops->pmu.load_lsfalcon_ucode = NULL; 814 gops->pmu.load_lsfalcon_ucode = NULL;
diff --git a/drivers/gpu/nvgpu/gp10b/pmu_gp10b.c b/drivers/gpu/nvgpu/gp10b/pmu_gp10b.c
index 5c7d1523..d268ab88 100644
--- a/drivers/gpu/nvgpu/gp10b/pmu_gp10b.c
+++ b/drivers/gpu/nvgpu/gp10b/pmu_gp10b.c
@@ -304,45 +304,6 @@ void gp10b_write_dmatrfbase(struct gk20a *g, u32 addr)
304 0x0); 304 0x0);
305} 305}
306 306
307int gp10b_init_pmu_setup_hw1(struct gk20a *g)
308{
309 struct nvgpu_pmu *pmu = &g->pmu;
310 int err;
311
312 nvgpu_log_fn(g, " ");
313
314 nvgpu_mutex_acquire(&pmu->isr_mutex);
315 nvgpu_flcn_reset(pmu->flcn);
316 pmu->isr_enabled = true;
317 nvgpu_mutex_release(&pmu->isr_mutex);
318
319 /* setup apertures - virtual */
320 gk20a_writel(g, pwr_fbif_transcfg_r(GK20A_PMU_DMAIDX_UCODE),
321 pwr_fbif_transcfg_mem_type_virtual_f());
322 gk20a_writel(g, pwr_fbif_transcfg_r(GK20A_PMU_DMAIDX_VIRT),
323 pwr_fbif_transcfg_mem_type_virtual_f());
324
325 /* setup apertures - physical */
326 gk20a_writel(g, pwr_fbif_transcfg_r(GK20A_PMU_DMAIDX_PHYS_VID),
327 pwr_fbif_transcfg_mem_type_physical_f() |
328 pwr_fbif_transcfg_target_local_fb_f());
329 gk20a_writel(g, pwr_fbif_transcfg_r(GK20A_PMU_DMAIDX_PHYS_SYS_COH),
330 pwr_fbif_transcfg_mem_type_physical_f() |
331 pwr_fbif_transcfg_target_coherent_sysmem_f());
332 gk20a_writel(g, pwr_fbif_transcfg_r(GK20A_PMU_DMAIDX_PHYS_SYS_NCOH),
333 pwr_fbif_transcfg_mem_type_physical_f() |
334 pwr_fbif_transcfg_target_noncoherent_sysmem_f());
335
336 err = g->ops.pmu.pmu_nsbootstrap(pmu);
337 if (err) {
338 return err;
339 }
340
341 nvgpu_log_fn(g, "done");
342 return 0;
343
344}
345
346bool gp10b_is_lazy_bootstrap(u32 falcon_id) 307bool gp10b_is_lazy_bootstrap(u32 falcon_id)
347{ 308{
348 bool enable_status = false; 309 bool enable_status = false;
diff --git a/drivers/gpu/nvgpu/gp10b/pmu_gp10b.h b/drivers/gpu/nvgpu/gp10b/pmu_gp10b.h
index 87c3ba79..4fd4c7c4 100644
--- a/drivers/gpu/nvgpu/gp10b/pmu_gp10b.h
+++ b/drivers/gpu/nvgpu/gp10b/pmu_gp10b.h
@@ -1,7 +1,7 @@
1/* 1/*
2 * GP10B PMU 2 * GP10B PMU
3 * 3 *
4 * Copyright (c) 2015-2017, NVIDIA CORPORATION. All rights reserved. 4 * Copyright (c) 2015-2018, NVIDIA CORPORATION. All rights reserved.
5 * 5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a 6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"), 7 * copy of this software and associated documentation files (the "Software"),
@@ -31,7 +31,6 @@ struct gk20a;
31bool gp10b_is_lazy_bootstrap(u32 falcon_id); 31bool gp10b_is_lazy_bootstrap(u32 falcon_id);
32bool gp10b_is_priv_load(u32 falcon_id); 32bool gp10b_is_priv_load(u32 falcon_id);
33bool gp10b_is_pmu_supported(struct gk20a *g); 33bool gp10b_is_pmu_supported(struct gk20a *g);
34int gp10b_init_pmu_setup_hw1(struct gk20a *g);
35void gp10b_pmu_elpg_statistics(struct gk20a *g, u32 pg_engine_id, 34void gp10b_pmu_elpg_statistics(struct gk20a *g, u32 pg_engine_id,
36 struct pmu_pg_stats_data *pg_stat_data); 35 struct pmu_pg_stats_data *pg_stat_data);
37int gp10b_pmu_setup_elpg(struct gk20a *g); 36int gp10b_pmu_setup_elpg(struct gk20a *g);