diff options
Diffstat (limited to 'drivers/gpu/nvgpu/gk20a/gr_gk20a.c')
-rw-r--r-- | drivers/gpu/nvgpu/gk20a/gr_gk20a.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/drivers/gpu/nvgpu/gk20a/gr_gk20a.c b/drivers/gpu/nvgpu/gk20a/gr_gk20a.c index e40f296e..4dfddf5d 100644 --- a/drivers/gpu/nvgpu/gk20a/gr_gk20a.c +++ b/drivers/gpu/nvgpu/gk20a/gr_gk20a.c | |||
@@ -3196,10 +3196,10 @@ static int gr_gk20a_init_gr_config(struct gk20a *g, struct gr_gk20a *gr) | |||
3196 | sizeof(u32)); | 3196 | sizeof(u32)); |
3197 | 3197 | ||
3198 | if (gr->gpc_tpc_mask == NULL) | 3198 | if (gr->gpc_tpc_mask == NULL) |
3199 | gr->gpc_tpc_mask = nvgpu_kzalloc(g, gr->gpc_count * | 3199 | gr->gpc_tpc_mask = nvgpu_kzalloc(g, gr->max_gpc_count * |
3200 | sizeof(u32)); | 3200 | sizeof(u32)); |
3201 | else | 3201 | else |
3202 | memset(gr->gpc_tpc_mask, 0, gr->gpc_count * | 3202 | memset(gr->gpc_tpc_mask, 0, gr->max_gpc_count * |
3203 | sizeof(u32)); | 3203 | sizeof(u32)); |
3204 | 3204 | ||
3205 | if (gr->gpc_zcb_count == NULL) | 3205 | if (gr->gpc_zcb_count == NULL) |
@@ -3228,6 +3228,13 @@ static int gr_gk20a_init_gr_config(struct gk20a *g, struct gr_gk20a *gr) | |||
3228 | !gr->gpc_ppc_count || !gr->gpc_skip_mask) | 3228 | !gr->gpc_ppc_count || !gr->gpc_skip_mask) |
3229 | goto clean_up; | 3229 | goto clean_up; |
3230 | 3230 | ||
3231 | for (gpc_index = 0; gpc_index < gr->max_gpc_count; gpc_index++) { | ||
3232 | if (g->ops.gr.get_gpc_tpc_mask) { | ||
3233 | gr->gpc_tpc_mask[gpc_index] = | ||
3234 | g->ops.gr.get_gpc_tpc_mask(g, gpc_index); | ||
3235 | } | ||
3236 | } | ||
3237 | |||
3231 | gr->ppc_count = 0; | 3238 | gr->ppc_count = 0; |
3232 | gr->tpc_count = 0; | 3239 | gr->tpc_count = 0; |
3233 | gr->zcb_count = 0; | 3240 | gr->zcb_count = 0; |
@@ -3243,10 +3250,6 @@ static int gr_gk20a_init_gr_config(struct gk20a *g, struct gr_gk20a *gr) | |||
3243 | gr_gpc0_fs_gpc_num_available_zculls_v(tmp); | 3250 | gr_gpc0_fs_gpc_num_available_zculls_v(tmp); |
3244 | gr->zcb_count += gr->gpc_zcb_count[gpc_index]; | 3251 | gr->zcb_count += gr->gpc_zcb_count[gpc_index]; |
3245 | 3252 | ||
3246 | if (g->ops.gr.get_gpc_tpc_mask) | ||
3247 | gr->gpc_tpc_mask[gpc_index] = | ||
3248 | g->ops.gr.get_gpc_tpc_mask(g, gpc_index); | ||
3249 | |||
3250 | for (pes_index = 0; pes_index < gr->pe_count_per_gpc; pes_index++) { | 3253 | for (pes_index = 0; pes_index < gr->pe_count_per_gpc; pes_index++) { |
3251 | if (!gr->pes_tpc_count[pes_index]) { | 3254 | if (!gr->pes_tpc_count[pes_index]) { |
3252 | gr->pes_tpc_count[pes_index] = | 3255 | gr->pes_tpc_count[pes_index] = |