summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/nvgpu/gm20b/ltc_gm20b.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/nvgpu/gm20b/ltc_gm20b.c')
-rw-r--r--drivers/gpu/nvgpu/gm20b/ltc_gm20b.c46
1 files changed, 45 insertions, 1 deletions
diff --git a/drivers/gpu/nvgpu/gm20b/ltc_gm20b.c b/drivers/gpu/nvgpu/gm20b/ltc_gm20b.c
index 5da21c64..43c90970 100644
--- a/drivers/gpu/nvgpu/gm20b/ltc_gm20b.c
+++ b/drivers/gpu/nvgpu/gm20b/ltc_gm20b.c
@@ -193,6 +193,50 @@ void gm20b_ltc_isr(struct gk20a *g)
193 gk20a_writel(g, ltc_ltc0_ltss_intr_r(), intr); 193 gk20a_writel(g, ltc_ltc0_ltss_intr_r(), intr);
194} 194}
195 195
196static void gm20b_ltc_g_elpg_flush_locked(struct gk20a *g)
197{
198 u32 data;
199 bool done[g->ltc_count];
200 s32 retry = 100;
201 int i;
202 int num_done = 0;
203 u32 ltc_d = ltc_ltc1_ltss_g_elpg_r() - ltc_ltc0_ltss_g_elpg_r();
204
205 gk20a_dbg_fn("");
206
207 for (i = 0; i < g->ltc_count; i++)
208 done[i] = 0;
209
210 gk20a_writel(g, ltc_ltcs_ltss_g_elpg_r(),
211 ltc_ltcs_ltss_g_elpg_flush_pending_f());
212 do {
213 for (i = 0; i < g->ltc_count; i++) {
214 if (done[i])
215 continue;
216
217 data = gk20a_readl(g,
218 ltc_ltc0_ltss_g_elpg_r() + ltc_d * i);
219
220 if (ltc_ltc0_ltss_g_elpg_flush_v(data)) {
221 gk20a_dbg_info("g_elpg_flush 0x%x", data);
222 } else {
223 done[i] = 1;
224 num_done++;
225 }
226 }
227
228 if (num_done < g->ltc_count) {
229 retry--;
230 usleep_range(20, 40);
231 } else
232 break;
233 } while (retry >= 0 || !tegra_platform_is_silicon());
234
235 if (retry < 0)
236 gk20a_warn(dev_from_gk20a(g),
237 "g_elpg_flush too many retries");
238}
239
196void gm20b_init_ltc(struct gpu_ops *gops) 240void gm20b_init_ltc(struct gpu_ops *gops)
197{ 241{
198 /* Gk20a reused ops. */ 242 /* Gk20a reused ops. */
@@ -209,6 +253,6 @@ void gm20b_init_ltc(struct gpu_ops *gops)
209 gops->ltc.init_fs_state = gm20b_ltc_init_fs_state; 253 gops->ltc.init_fs_state = gm20b_ltc_init_fs_state;
210 gops->ltc.init_comptags = gm20b_ltc_init_comptags; 254 gops->ltc.init_comptags = gm20b_ltc_init_comptags;
211 gops->ltc.cbc_ctrl = gm20b_ltc_cbc_ctrl; 255 gops->ltc.cbc_ctrl = gm20b_ltc_cbc_ctrl;
212 gops->ltc.elpg_flush = gk20a_mm_g_elpg_flush_locked; 256 gops->ltc.elpg_flush = gm20b_ltc_g_elpg_flush_locked;
213 gops->ltc.isr = gm20b_ltc_isr; 257 gops->ltc.isr = gm20b_ltc_isr;
214} 258}