1*4882a593Smuzhiyun /** 2*4882a593Smuzhiyun * Copyright (c) 2017 Redpine Signals Inc. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Permission to use, copy, modify, and/or distribute this software for any 5*4882a593Smuzhiyun * purpose with or without fee is hereby granted, provided that the above 6*4882a593Smuzhiyun * copyright notice and this permission notice appear in all copies. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 9*4882a593Smuzhiyun * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 10*4882a593Smuzhiyun * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 11*4882a593Smuzhiyun * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 12*4882a593Smuzhiyun * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 13*4882a593Smuzhiyun * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 14*4882a593Smuzhiyun * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 15*4882a593Smuzhiyun */ 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #ifndef __RSI_HEADER_H__ 18*4882a593Smuzhiyun #define __RSI_HEADER_H__ 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun #include <linux/skbuff.h> 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun /* HAL queue information */ 23*4882a593Smuzhiyun #define RSI_COEX_Q 0x0 24*4882a593Smuzhiyun #define RSI_BT_Q 0x2 25*4882a593Smuzhiyun #define RSI_WLAN_Q 0x3 26*4882a593Smuzhiyun #define RSI_WIFI_MGMT_Q 0x4 27*4882a593Smuzhiyun #define RSI_WIFI_DATA_Q 0x5 28*4882a593Smuzhiyun #define RSI_BT_MGMT_Q 0x6 29*4882a593Smuzhiyun #define RSI_BT_DATA_Q 0x7 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun enum rsi_coex_queues { 32*4882a593Smuzhiyun RSI_COEX_Q_INVALID = -1, 33*4882a593Smuzhiyun RSI_COEX_Q_COMMON = 0, 34*4882a593Smuzhiyun RSI_COEX_Q_BT, 35*4882a593Smuzhiyun RSI_COEX_Q_WLAN 36*4882a593Smuzhiyun }; 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun enum rsi_host_intf { 39*4882a593Smuzhiyun RSI_HOST_INTF_SDIO = 0, 40*4882a593Smuzhiyun RSI_HOST_INTF_USB 41*4882a593Smuzhiyun }; 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun struct rsi_proto_ops { 44*4882a593Smuzhiyun int (*coex_send_pkt)(void *priv, struct sk_buff *skb, u8 hal_queue); 45*4882a593Smuzhiyun enum rsi_host_intf (*get_host_intf)(void *priv); 46*4882a593Smuzhiyun void (*set_bt_context)(void *priv, void *context); 47*4882a593Smuzhiyun }; 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun struct rsi_mod_ops { 50*4882a593Smuzhiyun int (*attach)(void *priv, struct rsi_proto_ops *ops); 51*4882a593Smuzhiyun void (*detach)(void *priv); 52*4882a593Smuzhiyun int (*recv_pkt)(void *priv, const u8 *msg); 53*4882a593Smuzhiyun }; 54*4882a593Smuzhiyun 55*4882a593Smuzhiyun extern const struct rsi_mod_ops rsi_bt_ops; 56*4882a593Smuzhiyun #endif 57