Add snapshot of mba based modem pil driver based on 4.19 to 5.4 kernel. This is snapshot of the MBA base modem PIL driver as of msm-4.19 'commit <4a976aa23020441b8137243eb58778c6d7487ab1> ("<Merge "soc: qcom: add snapshot of MBA based modem PIL">")'. Move to upstream scm call API. Handle irq registration inside pil-q6v5 driver. Change-Id: I4db1614a94cd24410f654ab68f4ce68e60d45cdb Signed-off-by: Lijuan Gao <lijuang@codeaurora.org>
57 lines
1.5 KiB
C
57 lines
1.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (c) 2012-2021, The Linux Foundation. All rights reserved.
|
|
*/
|
|
|
|
#ifndef __MSM_PIL_MSA_H
|
|
#define __MSM_PIL_MSA_H
|
|
|
|
#include <soc/qcom/subsystem_restart.h>
|
|
|
|
#include "peripheral-loader.h"
|
|
|
|
struct modem_data {
|
|
struct device *dev;
|
|
struct q6v5_data *q6;
|
|
struct subsys_device *subsys;
|
|
struct subsys_desc subsys_desc;
|
|
void *ramdump_dev;
|
|
void *minidump_dev;
|
|
bool crash_shutdown;
|
|
u32 pas_id;
|
|
bool ignore_errors;
|
|
struct completion err_ready;
|
|
struct completion stop_ack;
|
|
void __iomem *rmb_base;
|
|
struct clk *xo;
|
|
struct pil_desc desc;
|
|
struct device mba_mem_dev;
|
|
struct device *mba_mem_dev_fixed;
|
|
unsigned long attrs_dma;
|
|
int is_not_loadable;
|
|
unsigned int err_fatal_irq;
|
|
unsigned int err_ready_irq;
|
|
unsigned int stop_ack_irq;
|
|
unsigned int wdog_bite_irq;
|
|
unsigned int generic_irq;
|
|
int ramdump_disable_irq;
|
|
int shutdown_ack_irq;
|
|
int force_stop_bit;
|
|
struct qcom_smem_state *state;
|
|
};
|
|
|
|
extern struct pil_reset_ops pil_msa_mss_ops;
|
|
extern struct pil_reset_ops pil_msa_mss_ops_selfauth;
|
|
extern struct pil_reset_ops pil_msa_femto_mba_ops;
|
|
|
|
int pil_mss_reset_load_mba(struct pil_desc *pil);
|
|
int pil_mss_make_proxy_votes(struct pil_desc *pil);
|
|
void pil_mss_remove_proxy_votes(struct pil_desc *pil);
|
|
int pil_mss_shutdown(struct pil_desc *pil);
|
|
int pil_mss_deinit_image(struct pil_desc *pil);
|
|
int __pil_mss_deinit_image(struct pil_desc *pil, bool err_path);
|
|
int pil_mss_assert_resets(struct q6v5_data *drv);
|
|
int pil_mss_deassert_resets(struct q6v5_data *drv);
|
|
int pil_mss_debug_reset(struct pil_desc *pil);
|
|
#endif
|