mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 06:43:09 +00:00
e9142f5c28
Add a common panic handler that invokes a stop request and sleep enough to let the remoteproc flush it's caches etc in order to aid post mortem debugging. For now a hard coded 200ms is returned to the remoteproc core, this value is taken from the downstream kernel. Reviewed-by: Mathieu Poirier <mathieu.poirier@linaro.org> Link: https://lore.kernel.org/r/20200324052904.738594-4-bjorn.andersson@linaro.org Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org>
48 lines
996 B
C
48 lines
996 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
#ifndef __QCOM_Q6V5_H__
|
|
#define __QCOM_Q6V5_H__
|
|
|
|
#include <linux/kernel.h>
|
|
#include <linux/completion.h>
|
|
|
|
struct rproc;
|
|
struct qcom_smem_state;
|
|
|
|
struct qcom_q6v5 {
|
|
struct device *dev;
|
|
struct rproc *rproc;
|
|
|
|
struct qcom_smem_state *state;
|
|
unsigned stop_bit;
|
|
|
|
int wdog_irq;
|
|
int fatal_irq;
|
|
int ready_irq;
|
|
int handover_irq;
|
|
int stop_irq;
|
|
|
|
bool handover_issued;
|
|
|
|
struct completion start_done;
|
|
struct completion stop_done;
|
|
|
|
int crash_reason;
|
|
|
|
bool running;
|
|
|
|
void (*handover)(struct qcom_q6v5 *q6v5);
|
|
};
|
|
|
|
int qcom_q6v5_init(struct qcom_q6v5 *q6v5, struct platform_device *pdev,
|
|
struct rproc *rproc, int crash_reason,
|
|
void (*handover)(struct qcom_q6v5 *q6v5));
|
|
|
|
int qcom_q6v5_prepare(struct qcom_q6v5 *q6v5);
|
|
int qcom_q6v5_unprepare(struct qcom_q6v5 *q6v5);
|
|
int qcom_q6v5_request_stop(struct qcom_q6v5 *q6v5);
|
|
int qcom_q6v5_wait_for_start(struct qcom_q6v5 *q6v5, int timeout);
|
|
unsigned long qcom_q6v5_panic(struct qcom_q6v5 *q6v5);
|
|
|
|
#endif
|