diff options
author | Sagar Kamble <skamble@nvidia.com> | 2021-02-02 11:32:23 -0500 |
---|---|---|
committer | mobile promotions <svcmobile_promotions@nvidia.com> | 2021-03-19 17:39:39 -0400 |
commit | 13fc430775eb0e39dc06e420d5c92dda7016f6ae (patch) | |
tree | a29ac9b259819124b8ffd0250feaab53fbb693c7 /drivers/gpu/nvgpu/vgpu | |
parent | 9170f2b77cba9aedd957acdde7c758e81e073cc0 (diff) |
gpu: nvgpu: retry tsg unbind if NEXT is set
The NEXT bit can remain set for the channel if timeslice expires before
scheduler clears it. Due to this nvgpu fails TSG unbind and in turn
nvrm_gpu fails channel close. In this case, checking the channel hw
state after some time can help see NEXT bit cleared by scheduler.
Reenable the tsg and return -EAGAIN to nvrm_gpu for it to retry again.
Bug 3144960
Bug 200520811
Change-Id: I35f417f02270e371a4e632986b73a00f8a4f921a
Signed-off-by: Sagar Kamble <skamble@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nvgpu/+/2468391
(cherry picked from commit cf287a4ef592e7329f813c076ec8bdad18dc5933)
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nvgpu/+/2479106
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
Reviewed-by: Deepak Nibade <dnibade@nvidia.com>
Reviewed-by: svc-mobile-coverity <svc-mobile-coverity@nvidia.com>
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com>
GVS: Gerrit_Virtual_Submit
Diffstat (limited to 'drivers/gpu/nvgpu/vgpu')
-rw-r--r-- | drivers/gpu/nvgpu/vgpu/gv11b/vgpu_tsg_gv11b.c | 4 | ||||
-rw-r--r-- | drivers/gpu/nvgpu/vgpu/tsg_vgpu.c | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/drivers/gpu/nvgpu/vgpu/gv11b/vgpu_tsg_gv11b.c b/drivers/gpu/nvgpu/vgpu/gv11b/vgpu_tsg_gv11b.c index 8c999161..84f295fe 100644 --- a/drivers/gpu/nvgpu/vgpu/gv11b/vgpu_tsg_gv11b.c +++ b/drivers/gpu/nvgpu/vgpu/gv11b/vgpu_tsg_gv11b.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (c) 2016-2018, NVIDIA CORPORATION. All rights reserved. | 2 | * Copyright (c) 2016-2021, NVIDIA CORPORATION. All rights reserved. |
3 | * | 3 | * |
4 | * Permission is hereby granted, free of charge, to any person obtaining a | 4 | * Permission is hereby granted, free of charge, to any person obtaining a |
5 | * copy of this software and associated documentation files (the "Software"), | 5 | * copy of this software and associated documentation files (the "Software"), |
@@ -54,7 +54,7 @@ int vgpu_gv11b_tsg_bind_channel(struct tsg_gk20a *tsg, | |||
54 | nvgpu_err(tsg->g, | 54 | nvgpu_err(tsg->g, |
55 | "vgpu_gv11b_tsg_bind_channel failed, ch %d tsgid %d", | 55 | "vgpu_gv11b_tsg_bind_channel failed, ch %d tsgid %d", |
56 | ch->chid, tsg->tsgid); | 56 | ch->chid, tsg->tsgid); |
57 | gk20a_tsg_unbind_channel(ch); | 57 | gk20a_tsg_unbind_channel(ch, true); |
58 | } | 58 | } |
59 | 59 | ||
60 | return err; | 60 | return err; |
diff --git a/drivers/gpu/nvgpu/vgpu/tsg_vgpu.c b/drivers/gpu/nvgpu/vgpu/tsg_vgpu.c index d6060e06..d1f64d97 100644 --- a/drivers/gpu/nvgpu/vgpu/tsg_vgpu.c +++ b/drivers/gpu/nvgpu/vgpu/tsg_vgpu.c | |||
@@ -1,5 +1,5 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (c) 2016-2020, NVIDIA CORPORATION. All rights reserved. | 2 | * Copyright (c) 2016-2021, NVIDIA CORPORATION. All rights reserved. |
3 | * | 3 | * |
4 | * Permission is hereby granted, free of charge, to any person obtaining a | 4 | * Permission is hereby granted, free of charge, to any person obtaining a |
5 | * copy of this software and associated documentation files (the "Software"), | 5 | * copy of this software and associated documentation files (the "Software"), |
@@ -112,7 +112,7 @@ int vgpu_tsg_bind_channel(struct tsg_gk20a *tsg, | |||
112 | nvgpu_err(tsg->g, | 112 | nvgpu_err(tsg->g, |
113 | "vgpu_tsg_bind_channel failed, ch %d tsgid %d", | 113 | "vgpu_tsg_bind_channel failed, ch %d tsgid %d", |
114 | ch->chid, tsg->tsgid); | 114 | ch->chid, tsg->tsgid); |
115 | gk20a_tsg_unbind_channel(ch); | 115 | gk20a_tsg_unbind_channel(ch, true); |
116 | } | 116 | } |
117 | 117 | ||
118 | return err; | 118 | return err; |