diff options
author | Terje Bergstrom <tbergstrom@nvidia.com> | 2017-05-11 16:12:03 -0400 |
---|---|---|
committer | mobile promotions <svcmobile_promotions@nvidia.com> | 2017-05-26 06:34:08 -0400 |
commit | 726900b8433294fd89a6d730d2fec9de8e33afda (patch) | |
tree | 6d6aa5b6e07a792441e43b74ea273f85933eebe0 /drivers/gpu/nvgpu/gk20a/mc_gk20a.h | |
parent | 0bb47c3675d2030545d40353931e2b8120541de4 (diff) |
gpu: nvgpu: Split stalling interrupt handling
Split handling of stalling interrupt to Linux specific chip
agnostic and OS independent chip specific parts.
Linux specific chip independent part contains handler for ISR
and passing the control to a bottom half. It uses the new MC HALs
intr_stall (query interrupt status), intr_pause (pause interrupts)
and intr_resume (resume interrupts).
MC HAL isr_stall now returns void and gets called in thread context
and thus remove isr_thread_stall and replace the implementation with
isr_stall.
JIRA NVGPU-26
Change-Id: I206f330f6fc4a1f4def47c5f986585ac4080216d
Signed-off-by: Terje Bergstrom <tbergstrom@nvidia.com>
Reviewed-on: http://git-master/r/1480243
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com>
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
Diffstat (limited to 'drivers/gpu/nvgpu/gk20a/mc_gk20a.h')
-rw-r--r-- | drivers/gpu/nvgpu/gk20a/mc_gk20a.h | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/gpu/nvgpu/gk20a/mc_gk20a.h b/drivers/gpu/nvgpu/gk20a/mc_gk20a.h index 9c70eba1..2b4a183e 100644 --- a/drivers/gpu/nvgpu/gk20a/mc_gk20a.h +++ b/drivers/gpu/nvgpu/gk20a/mc_gk20a.h | |||
@@ -19,7 +19,10 @@ void gk20a_init_mc(struct gpu_ops *gops); | |||
19 | void mc_gk20a_intr_enable(struct gk20a *g); | 19 | void mc_gk20a_intr_enable(struct gk20a *g); |
20 | void mc_gk20a_intr_unit_config(struct gk20a *g, bool enable, | 20 | void mc_gk20a_intr_unit_config(struct gk20a *g, bool enable, |
21 | bool is_stalling, u32 mask); | 21 | bool is_stalling, u32 mask); |
22 | irqreturn_t mc_gk20a_isr_stall(struct gk20a *g); | 22 | void mc_gk20a_isr_stall(struct gk20a *g); |
23 | u32 mc_gk20a_intr_stall(struct gk20a *g); | ||
24 | void mc_gk20a_intr_stall_pause(struct gk20a *g); | ||
25 | void mc_gk20a_intr_stall_resume(struct gk20a *g); | ||
23 | irqreturn_t mc_gk20a_isr_nonstall(struct gk20a *g); | 26 | irqreturn_t mc_gk20a_isr_nonstall(struct gk20a *g); |
24 | irqreturn_t mc_gk20a_intr_thread_stall(struct gk20a *g); | 27 | irqreturn_t mc_gk20a_intr_thread_stall(struct gk20a *g); |
25 | void mc_gk20a_intr_thread_nonstall(struct gk20a *g, u32 intr); | 28 | void mc_gk20a_intr_thread_nonstall(struct gk20a *g, u32 intr); |