diff options
Diffstat (limited to 'drivers/gpu/nvgpu/gp10b')
-rw-r--r-- | drivers/gpu/nvgpu/gp10b/hal_gp10b.c | 5 | ||||
-rw-r--r-- | drivers/gpu/nvgpu/gp10b/pmu_gp10b.c | 39 | ||||
-rw-r--r-- | drivers/gpu/nvgpu/gp10b/pmu_gp10b.h | 3 |
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 | ||
307 | int 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 | |||
346 | bool gp10b_is_lazy_bootstrap(u32 falcon_id) | 307 | bool 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; | |||
31 | bool gp10b_is_lazy_bootstrap(u32 falcon_id); | 31 | bool gp10b_is_lazy_bootstrap(u32 falcon_id); |
32 | bool gp10b_is_priv_load(u32 falcon_id); | 32 | bool gp10b_is_priv_load(u32 falcon_id); |
33 | bool gp10b_is_pmu_supported(struct gk20a *g); | 33 | bool gp10b_is_pmu_supported(struct gk20a *g); |
34 | int gp10b_init_pmu_setup_hw1(struct gk20a *g); | ||
35 | void gp10b_pmu_elpg_statistics(struct gk20a *g, u32 pg_engine_id, | 34 | void 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); |
37 | int gp10b_pmu_setup_elpg(struct gk20a *g); | 36 | int gp10b_pmu_setup_elpg(struct gk20a *g); |