Thomas Fleury
95bb19827e
gpu: nvgpu: add sw quiesce
...
For safety build, nvgpu driver should enter SW quiesce state
in case an uncorrectable error has occurred. In this state, any
activity on the GPU should be prevented, without powering off the GPU.
Also, a minimal set of operations should be used to enter SW quiesce
state.
Entering SW quiesce state does the following:
- set sw_quiesce_pending: when this flag is set, interrupt
handlers exit after masking interrupts. This should help mitigate
an interrupt storm.
- wake up thread to complete quiescing.
The thread performs the following:
- set NVGPU_DRIVER_IS_DYING to prevent allocation of new resources
- disable interrupts
- disable fifo scheduling
- preempt all runlists
- set error notifier for all active channels
Note: for channels with usermode submit enabled, userspace can
still ring doorbell, but this will not trigger any work on
engines since fifo scheduling is disabled.
Jira NVGPU-3493
Change-Id: I639a32da754d8833f54dcec1fa23135721d8d89a
Signed-off-by: Thomas Fleury <tfleury@nvidia.com >
Reviewed-on: https://git-master.nvidia.com/r/2172391
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com >
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com >
2019-08-27 10:37:21 -07:00
..
2019-07-19 00:05:40 -07:00
2019-07-23 13:27:18 -07:00
2019-01-29 21:55:37 -08:00
2018-09-25 13:10:19 -07:00
2018-08-29 20:34:34 -07:00
2018-09-25 13:10:19 -07:00
2018-08-29 20:34:34 -07:00
2019-06-24 17:36:29 -07:00
2019-05-06 02:56:53 -07:00
2019-05-06 02:56:53 -07:00
2019-07-01 07:05:18 -07:00
2018-06-15 17:47:31 -07:00
2019-03-18 20:19:10 -07:00
2019-01-31 12:04:10 -08:00
2018-06-15 17:47:31 -07:00
2018-06-15 17:47:31 -07:00
2019-07-10 15:26:08 -07:00
2018-06-27 07:30:06 -07:00
2018-06-15 17:47:31 -07:00
2018-06-15 17:47:31 -07:00
2019-04-19 13:55:11 -07:00
2019-04-19 13:55:11 -07:00
2019-04-22 14:15:22 -07:00
2018-09-05 04:51:40 -07:00
2019-07-26 04:07:01 -07:00
2019-07-26 04:07:01 -07:00
2019-03-16 05:05:41 -07:00
2019-06-11 09:46:24 -07:00
2019-05-17 01:49:27 -07:00
2018-06-15 17:47:31 -07:00
2019-04-22 03:15:09 -07:00
2018-06-15 17:47:31 -07:00
2018-06-15 17:47:31 -07:00
2018-06-15 17:47:31 -07:00
2018-10-31 15:25:23 -07:00
2018-06-15 17:47:31 -07:00
2019-03-27 10:26:02 -07:00
2018-07-24 16:10:58 -07:00
2019-01-10 20:09:38 -08:00
2018-09-05 04:51:50 -07:00
2019-06-04 14:15:08 -07:00
2018-06-15 17:47:31 -07:00
2019-02-11 20:55:07 -08:00
2019-02-11 20:55:07 -08:00
2018-06-15 17:47:31 -07:00
2018-06-15 17:47:31 -07:00
2019-06-13 23:05:43 -07:00
2019-06-13 23:05:43 -07:00
2019-07-29 05:30:28 -07:00
2019-02-01 09:45:57 -08:00
2018-10-31 15:25:23 -07:00
2018-06-15 17:47:31 -07:00
2019-07-23 13:27:18 -07:00
2019-08-01 21:57:18 -07:00
2019-06-25 04:37:08 -07:00
2019-06-25 04:37:08 -07:00
2019-05-01 15:06:57 -07:00
2019-08-23 04:18:13 -07:00
2018-06-15 17:47:31 -07:00
2018-06-15 17:47:31 -07:00
2018-09-25 13:10:19 -07:00
2019-07-23 13:27:18 -07:00
2019-05-06 02:56:53 -07:00
2019-02-20 23:05:04 -08:00
2018-06-15 17:47:31 -07:00
2019-08-27 10:37:21 -07:00
2018-06-15 17:47:31 -07:00
2019-04-16 13:04:27 -07:00
2019-06-21 04:35:25 -07:00
2018-06-15 17:47:31 -07:00
2019-08-01 04:37:31 -07:00
2019-05-06 02:56:53 -07:00
2019-07-12 15:55:49 -07:00
2019-07-23 13:27:18 -07:00
2018-10-29 08:04:25 -07:00
2019-07-23 13:27:18 -07:00
2018-07-05 21:48:44 -07:00
2019-07-23 13:27:18 -07:00
2018-06-15 17:47:31 -07:00
2019-06-11 09:46:24 -07:00
2018-06-15 17:47:31 -07:00
2018-11-07 10:35:13 -08:00
2019-05-03 13:08:00 -07:00
2019-08-01 04:37:31 -07:00
2019-08-01 21:57:18 -07:00
2019-07-23 13:27:29 -07:00
2019-06-06 16:27:23 -07:00
2019-04-16 13:04:27 -07:00
2018-06-15 17:47:31 -07:00
2019-08-27 10:37:21 -07:00
2019-08-27 10:37:21 -07:00
2019-06-25 04:37:08 -07:00
2018-06-15 17:47:31 -07:00
2019-08-19 07:07:18 -07:00
2019-03-07 11:45:07 -08:00
2019-06-11 09:46:24 -07:00
2019-06-11 09:46:24 -07:00
2018-07-26 00:06:07 -07:00
2019-05-06 02:56:53 -07:00
2019-05-06 02:56:53 -07:00
2019-05-06 02:56:53 -07:00
2019-05-28 03:15:22 -07:00
2019-04-22 05:25:48 -07:00
2018-08-29 20:34:34 -07:00
2018-09-09 17:22:24 -07:00
2018-08-29 20:34:34 -07:00
2018-09-09 17:22:24 -07:00
2018-09-09 17:22:24 -07:00
2019-07-26 04:07:01 -07:00
2018-09-05 04:51:36 -07:00
2019-07-26 04:07:01 -07:00
2018-11-08 19:35:09 -08:00
2018-12-13 04:56:14 -08:00
2018-08-29 20:34:34 -07:00
2019-05-15 22:29:40 -07:00
2019-08-27 10:37:21 -07:00
2018-10-12 17:35:10 +05:30
2019-08-23 04:18:13 -07:00
2018-06-15 17:47:31 -07:00
2019-05-23 00:56:55 -07:00
2018-06-15 17:47:31 -07:00
2019-08-23 04:18:13 -07:00
2019-05-06 16:46:00 -07:00
2018-06-15 17:47:31 -07:00
2019-08-12 00:47:55 -07:00
2018-06-15 17:47:31 -07:00
2019-04-10 06:03:59 -07:00
2018-06-15 17:47:31 -07:00
2019-07-23 13:27:18 -07:00
2019-05-06 02:56:53 -07:00
2019-08-21 23:38:56 -07:00
2018-09-25 13:10:19 -07:00
2019-07-24 10:16:30 -07:00
2019-05-06 02:56:53 -07:00
2019-05-06 02:56:53 -07:00
2019-08-12 00:47:55 -07:00
2018-06-15 17:47:31 -07:00
2019-01-25 01:35:29 -08:00
2019-07-24 17:04:38 -07:00
2019-08-22 14:07:25 -07:00