1*5113495bSYour Name /* 2*5113495bSYour Name * Copyright (c) 2013-2018,2020-2021 The Linux Foundation. All rights reserved. 3*5113495bSYour Name * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved. 4*5113495bSYour Name * 5*5113495bSYour Name * Permission to use, copy, modify, and/or distribute this software for 6*5113495bSYour Name * any purpose with or without fee is hereby granted, provided that the 7*5113495bSYour Name * above copyright notice and this permission notice appear in all 8*5113495bSYour Name * copies. 9*5113495bSYour Name * 10*5113495bSYour Name * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL 11*5113495bSYour Name * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED 12*5113495bSYour Name * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE 13*5113495bSYour Name * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL 14*5113495bSYour Name * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR 15*5113495bSYour Name * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER 16*5113495bSYour Name * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 17*5113495bSYour Name * PERFORMANCE OF THIS SOFTWARE. 18*5113495bSYour Name */ 19*5113495bSYour Name 20*5113495bSYour Name #ifndef __AHB_API_H 21*5113495bSYour Name #define __AHB_API_H 22*5113495bSYour Name struct hif_exec_context; 23*5113495bSYour Name 24*5113495bSYour Name QDF_STATUS hif_ahb_open(struct hif_softc *hif_ctx, 25*5113495bSYour Name enum qdf_bus_type bus_type); 26*5113495bSYour Name void hif_ahb_close(struct hif_softc *hif_ctx); 27*5113495bSYour Name 28*5113495bSYour Name 29*5113495bSYour Name void hif_ahb_disable_isr(struct hif_softc *hif_ctx); 30*5113495bSYour Name void hif_ahb_nointrs(struct hif_softc *scn); 31*5113495bSYour Name QDF_STATUS hif_ahb_enable_bus(struct hif_softc *ol_sc, 32*5113495bSYour Name struct device *dev, void *bdev, 33*5113495bSYour Name const struct hif_bus_id *bid, 34*5113495bSYour Name enum hif_enable_type type); 35*5113495bSYour Name void hif_ahb_disable_bus(struct hif_softc *scn); 36*5113495bSYour Name int hif_ahb_bus_configure(struct hif_softc *scn); 37*5113495bSYour Name void hif_ahb_irq_disable(struct hif_softc *scn, int ce_id); 38*5113495bSYour Name void hif_ahb_irq_enable(struct hif_softc *scn, int ce_id); 39*5113495bSYour Name void hif_ahb_exec_grp_irq_disable(struct hif_exec_context *hif_ext_grp); 40*5113495bSYour Name void hif_ahb_exec_grp_irq_enable(struct hif_exec_context *hif_ext_grp); 41*5113495bSYour Name int hif_ahb_dump_registers(struct hif_softc *scn); 42*5113495bSYour Name 43*5113495bSYour Name int hif_ahb_configure_irq(struct hif_pci_softc *sc); 44*5113495bSYour Name int hif_ahb_configure_irq_by_ceid(struct hif_softc *sc, int ce_id); 45*5113495bSYour Name int hif_ahb_configure_grp_irq(struct hif_softc *scn, 46*5113495bSYour Name struct hif_exec_context *hif_ext_grp); 47*5113495bSYour Name void hif_ahb_deconfigure_grp_irq(struct hif_softc *scn); 48*5113495bSYour Name bool hif_ahb_needs_bmi(struct hif_softc *scn); 49*5113495bSYour Name void hif_ahb_display_stats(struct hif_softc *scn); 50*5113495bSYour Name void hif_ahb_clear_stats(struct hif_softc *scn); 51*5113495bSYour Name #endif 52