| /* |
| * |
| * (C) COPYRIGHT 2012-2016 ARM Limited. All rights reserved. |
| * |
| * This program is free software and is provided to you under the terms of the |
| * GNU General Public License version 2 as published by the Free Software |
| * Foundation, and any use by you of this program is subject to the terms |
| * of such GNU licence. |
| * |
| * A copy of the licence is included with the program, and can also be obtained |
| * from Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301, USA. |
| * |
| */ |
| |
| |
| |
| #ifndef _KBASE_DEBUG_JOB_FAULT_H |
| #define _KBASE_DEBUG_JOB_FAULT_H |
| |
| #include <linux/debugfs.h> |
| #include <linux/seq_file.h> |
| |
| #define REGISTER_DUMP_TERMINATION_FLAG 0xFFFFFFFF |
| |
| /** |
| * kbase_debug_job_fault_dev_init - Create the fault event wait queue |
| * per device and initialize the required lists. |
| * @kbdev: Device pointer |
| * |
| * Return: Zero on success or a negative error code. |
| */ |
| int kbase_debug_job_fault_dev_init(struct kbase_device *kbdev); |
| |
| /** |
| * kbase_debug_job_fault_debugfs_init - Initialize job fault debug sysfs |
| * @kbdev: Device pointer |
| */ |
| void kbase_debug_job_fault_debugfs_init(struct kbase_device *kbdev); |
| |
| /** |
| * kbase_debug_job_fault_dev_term - Clean up resources created in |
| * kbase_debug_job_fault_dev_init. |
| * @kbdev: Device pointer |
| */ |
| void kbase_debug_job_fault_dev_term(struct kbase_device *kbdev); |
| |
| /** |
| * kbase_debug_job_fault_context_init - Initialize the relevant |
| * data structure per context |
| * @kctx: KBase context pointer |
| */ |
| void kbase_debug_job_fault_context_init(struct kbase_context *kctx); |
| |
| /** |
| * kbase_debug_job_fault_context_term - Release the relevant |
| * resource per context |
| * @kctx: KBase context pointer |
| */ |
| void kbase_debug_job_fault_context_term(struct kbase_context *kctx); |
| |
| /** |
| * kbase_debug_job_fault_process - Process the failed job. |
| * It will send a event and wake up the job fault waiting queue |
| * Then create a work queue to wait for job dump finish |
| * This function should be called in the interrupt handler and before |
| * jd_done that make sure the jd_done_worker will be delayed until the |
| * job dump finish |
| * @katom: The failed atom pointer |
| * @completion_code: the job status |
| * @return true if dump is going on |
| */ |
| bool kbase_debug_job_fault_process(struct kbase_jd_atom *katom, |
| u32 completion_code); |
| |
| |
| /** |
| * kbase_debug_job_fault_reg_snapshot_init - Set the interested registers |
| * address during the job fault process, the relevant registers will |
| * be saved when a job fault happen |
| * @kctx: KBase context pointer |
| * @reg_range: Maximum register address space |
| * @return true if initializing successfully |
| */ |
| bool kbase_debug_job_fault_reg_snapshot_init(struct kbase_context *kctx, |
| int reg_range); |
| |
| /** |
| * kbase_job_fault_get_reg_snapshot - Read the interested registers for |
| * failed job dump |
| * @kctx: KBase context pointer |
| * @return true if getting registers successfully |
| */ |
| bool kbase_job_fault_get_reg_snapshot(struct kbase_context *kctx); |
| |
| #endif /*_KBASE_DEBUG_JOB_FAULT_H*/ |