summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/nvgpu/gv11b/fifo_gv11b.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c b/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
index df7ab5af..a153de7c 100644
--- a/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
+++ b/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
@@ -202,6 +202,16 @@ static u32 gv11b_userd_gp_get(struct gk20a *g, struct channel_gk20a *c)
202 offset + ram_userd_gp_get_w()); 202 offset + ram_userd_gp_get_w());
203} 203}
204 204
205static u64 gv11b_userd_pb_get(struct gk20a *g, struct channel_gk20a *c)
206{
207 struct nvgpu_mem *userd_mem = &g->fifo.userd;
208 u32 offset = c->hw_chid * (g->fifo.userd_entry_size / sizeof(u32));
209 u32 lo = nvgpu_mem_rd32(g, userd_mem, offset + ram_userd_get_w());
210 u32 hi = nvgpu_mem_rd32(g, userd_mem, offset + ram_userd_get_hi_w());
211
212 return ((u64)hi << 32) | lo;
213}
214
205static void gv11b_userd_gp_put(struct gk20a *g, struct channel_gk20a *c) 215static void gv11b_userd_gp_put(struct gk20a *g, struct channel_gk20a *c)
206{ 216{
207 struct nvgpu_mem *userd_mem = &g->fifo.userd; 217 struct nvgpu_mem *userd_mem = &g->fifo.userd;
@@ -1412,6 +1422,7 @@ void gv11b_init_fifo(struct gpu_ops *gops)
1412 gops->fifo.get_num_fifos = gv11b_fifo_get_num_fifos; 1422 gops->fifo.get_num_fifos = gv11b_fifo_get_num_fifos;
1413 gops->fifo.userd_gp_get = gv11b_userd_gp_get; 1423 gops->fifo.userd_gp_get = gv11b_userd_gp_get;
1414 gops->fifo.userd_gp_put = gv11b_userd_gp_put; 1424 gops->fifo.userd_gp_put = gv11b_userd_gp_put;
1425 gops->fifo.userd_pb_get = gv11b_userd_pb_get;
1415 gops->fifo.setup_ramfc = channel_gv11b_setup_ramfc; 1426 gops->fifo.setup_ramfc = channel_gv11b_setup_ramfc;
1416 gops->fifo.resetup_ramfc = NULL; 1427 gops->fifo.resetup_ramfc = NULL;
1417 gops->fifo.unbind_channel = channel_gv11b_unbind; 1428 gops->fifo.unbind_channel = channel_gv11b_unbind;