kernel-brax3-ubuntu-touch/drivers/misc/mediatek/connectivity/common/wmt_build_in_adapter.h
erascape f319b992b1 kernel-5.15: Initial import brax3 UT kernel
* halium configs enabled

Signed-off-by: erascape <erascape@proton.me>
2025-09-23 15:17:10 +00:00

58 lines
2.2 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/*
* Copyright (c) 2019 MediaTek Inc.
*/
#ifndef WMT_BUILD_IN_ADAPTER_H
#define WMT_BUILD_IN_ADAPTER_H
#include <mtk_wcn_cmb_stub.h>
#include <linux/types.h>
#include <linux/fs.h>
/*******************************************************************************
* Bridging from platform -> wmt_drv.ko
******************************************************************************/
typedef int (*wmt_bridge_thermal_query_cb)(void);
typedef int (*wmt_bridge_trigger_assert_cb)(void);
typedef void (*wmt_bridge_connsys_clock_fail_dump_cb)(void);
typedef int (*wmt_bridge_conninfra_reg_readable)(void);
typedef int (*wmt_bridge_conninfra_reg_is_bus_hang)(void);
typedef ssize_t (*wmt_bridge_debug_write_cb)(struct file *, const char __user *, size_t, loff_t *);
typedef ssize_t (*wmt_bridge_debug_read_cb)(struct file *, char __user *, size_t, loff_t *);
struct wmt_platform_bridge {
wmt_bridge_thermal_query_cb thermal_query_cb;
wmt_bridge_trigger_assert_cb trigger_assert_cb;
wmt_bridge_connsys_clock_fail_dump_cb clock_fail_dump_cb;
/* for CONNAC 2 */
wmt_bridge_conninfra_reg_readable conninfra_reg_readable_cb;
wmt_bridge_conninfra_reg_is_bus_hang conninfra_reg_is_bus_hang_cb;
};
void wmt_export_platform_bridge_register(struct wmt_platform_bridge *cb);
void wmt_export_platform_bridge_unregister(void);
struct wmt_platform_dbg_bridge {
ssize_t (*write_cb)(struct file *filep, const char __user *buffer, size_t count,
loff_t *f_pos);
ssize_t (*read_cb)(struct file *filep, char __user *buffer, size_t count, loff_t *f_pos);
};
void wmt_export_platform_dbg_bridge_register(const struct wmt_platform_dbg_bridge *cb);
void wmt_export_platform_dbg_bridge_unregister(void);
/*******************************************************************************
* SDIO integration with platform MMC driver
******************************************************************************/
extern unsigned int wifi_irq;
extern pm_callback_t mtk_wcn_cmb_sdio_pm_cb;
extern void *mtk_wcn_cmb_sdio_pm_data;
void wmt_export_mtk_wcn_cmb_sdio_disable_eirq(void);
int wmt_export_mtk_wcn_sdio_irq_flag_set(int flag);
#endif /* WMT_BUILD_IN_ADAPTER_H */