gpu: nvgpu: gr/init update

move gr_gk20a_init_fs_state function to common/gr/init as
nvgpu_gr_init_fs_state.

JIRA NVGPU-1885

Change-Id: I37aad483be268e2b722883719376beb142c0b7ea
Signed-off-by: Vinod G <vinodg@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/2072413
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com>
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
This commit is contained in:
Vinod G
2019-03-13 23:00:17 -07:00
committed by mobile promotions
parent e29c1a6c03
commit 43672dd237
6 changed files with 55 additions and 55 deletions

View File

@@ -30,3 +30,55 @@ u32 nvgpu_gr_get_idle_timeout(struct gk20a *g)
g->gr_idle_timeout_default : UINT_MAX;
}
int nvgpu_gr_init_fs_state(struct gk20a *g)
{
u32 tpc_index, gpc_index;
u32 sm_id = 0;
u32 fuse_tpc_mask;
u32 gpc_cnt, tpc_cnt, max_tpc_cnt;
int err = 0;
struct nvgpu_gr_config *gr_config = g->gr.config;
nvgpu_log_fn(g, " ");
if (g->ops.gr.init_sm_id_table != NULL) {
err = g->ops.gr.init_sm_id_table(g);
if (err != 0) {
return err;
}
/* Is table empty ? */
if (g->gr.no_of_sm == 0U) {
return -EINVAL;
}
}
for (sm_id = 0; sm_id < g->gr.no_of_sm; sm_id++) {
tpc_index = g->gr.sm_to_cluster[sm_id].tpc_index;
gpc_index = g->gr.sm_to_cluster[sm_id].gpc_index;
g->ops.gr.program_sm_id_numbering(g, gpc_index, tpc_index, sm_id);
}
g->ops.gr.init.pd_tpc_per_gpc(g);
/* gr__setup_pd_mapping */
g->ops.gr.setup_rop_mapping(g, &g->gr);
g->ops.gr.init.pd_skip_table_gpc(g);
fuse_tpc_mask = g->ops.gr.config.get_gpc_tpc_mask(g, gr_config, 0);
gpc_cnt = nvgpu_gr_config_get_gpc_count(gr_config);
tpc_cnt = nvgpu_gr_config_get_tpc_count(gr_config);
max_tpc_cnt = nvgpu_gr_config_get_max_tpc_count(gr_config);
if ((g->tpc_fs_mask_user != 0U) &&
(fuse_tpc_mask == BIT32(max_tpc_cnt) - 1U)) {
u32 val = g->tpc_fs_mask_user;
val &= BIT32(max_tpc_cnt) - U32(1);
tpc_cnt = (u32)hweight32(val);
}
g->ops.gr.init.cwd_gpcs_tpcs_num(g, gpc_cnt, tpc_cnt);
return err;
}