xref: /linux/drivers/net/wireless/ath/ath11k/mhi.h (revision df9c299371054cb725eef730fd0f1d0fe2ed6bb0)
1 /* SPDX-License-Identifier: BSD-3-Clause-Clear */
2 /*
3  * Copyright (c) 2020 The Linux Foundation. All rights reserved.
4  * Copyright (c) 2022, 2024-2025 Qualcomm Innovation Center, Inc. All rights reserved.
5  */
6 #ifndef _ATH11K_MHI_H
7 #define _ATH11K_MHI_H
8 
9 #include "pci.h"
10 
11 #define PCIE_TXVECDB				0x360
12 #define PCIE_TXVECSTATUS			0x368
13 #define PCIE_RXVECDB				0x394
14 #define PCIE_RXVECSTATUS			0x39C
15 
16 #define MHISTATUS				0x48
17 #define MHICTRL					0x38
18 #define MHICTRL_RESET_MASK			0x2
19 
20 int ath11k_mhi_start(struct ath11k_pci *ar_pci);
21 void ath11k_mhi_stop(struct ath11k_pci *ar_pci, bool is_suspend);
22 int ath11k_mhi_register(struct ath11k_pci *ar_pci);
23 void ath11k_mhi_unregister(struct ath11k_pci *ar_pci);
24 void ath11k_mhi_set_mhictrl_reset(struct ath11k_base *ab);
25 void ath11k_mhi_clear_vector(struct ath11k_base *ab);
26 
27 int ath11k_mhi_suspend(struct ath11k_pci *ar_pci);
28 int ath11k_mhi_resume(struct ath11k_pci *ar_pci);
29 void ath11k_mhi_coredump(struct mhi_controller *mhi_ctrl, bool in_panic);
30 
31 #endif
32