summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
diff options
context:
space:
mode:
authorDebarshi Dutta <ddutta@nvidia.com>2018-11-30 00:27:05 -0500
committermobile promotions <svcmobile_promotions@nvidia.com>2019-02-11 11:18:47 -0500
commit18643ac1357a845d204d6dabd98359a0ab0509a7 (patch)
treec04d1f18668eb0fafae7c345780db52d5064d185 /drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
parenta8f0cb89f423093c334202dcfe43cb5729efca85 (diff)
gpu: nvgpu: replace input param chid with pointer to channel
preempt_channel needs to use the channel to pass it to other public functions, get access to a tsg etc. This qualifies it to take a pointer to a channel as an input parameter instead of a chid. Increment the channel ref counter using the function gk20a_channel_from_id in functions where we get the chid from the h/w registers directly. Once the prempt_channel function call is done, use a gk20a_channel_put on the referenced channel. Jira NVGPU-1461 Change-Id: I6c87c8104cfcb418d468c8c590087fd4aeabf4bd Signed-off-by: Debarshi Dutta <ddutta@nvidia.com> Reviewed-on: https://git-master.nvidia.com/r/1963200 (cherry picked from commit 9abe9fe062367902ede7721cff55396859f8e4e8 in dev-kernel) Reviewed-on: https://git-master.nvidia.com/r/2013728 Reviewed-by: svc-mobile-coverity <svc-mobile-coverity@nvidia.com> GVS: Gerrit_Virtual_Submit Reviewed-by: Bibek Basu <bbasu@nvidia.com> Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com> Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
Diffstat (limited to 'drivers/gpu/nvgpu/gv11b/fifo_gv11b.c')
-rw-r--r--drivers/gpu/nvgpu/gv11b/fifo_gv11b.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c b/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
index fb9c7712..8b5eef82 100644
--- a/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
+++ b/drivers/gpu/nvgpu/gv11b/fifo_gv11b.c
@@ -801,22 +801,17 @@ int gv11b_fifo_is_preempt_pending(struct gk20a *g, u32 id,
801 return ret; 801 return ret;
802} 802}
803 803
804int gv11b_fifo_preempt_channel(struct gk20a *g, u32 chid) 804int gv11b_fifo_preempt_channel(struct gk20a *g, struct channel_gk20a *ch)
805{ 805{
806 struct fifo_gk20a *f = &g->fifo;
807 struct tsg_gk20a *tsg = NULL; 806 struct tsg_gk20a *tsg = NULL;
808 807
809 if (chid == FIFO_INVAL_CHANNEL_ID) { 808 tsg = tsg_gk20a_from_ch(ch);
810 return 0;
811 }
812
813 tsg = tsg_gk20a_from_ch(&f->channel[chid]);
814 809
815 if (tsg == NULL) { 810 if (tsg == NULL) {
816 return 0; 811 return 0;
817 } 812 }
818 813
819 nvgpu_log_info(g, "chid:%d tsgid:%d", chid, tsg->tsgid); 814 nvgpu_log_info(g, "chid:%d tsgid:%d", ch->chid, tsg->tsgid);
820 815
821 /* Preempt tsg. Channel preempt is NOOP */ 816 /* Preempt tsg. Channel preempt is NOOP */
822 return g->ops.fifo.preempt_tsg(g, tsg); 817 return g->ops.fifo.preempt_tsg(g, tsg);