| /* SPDX-License-Identifier: GPL-2.0 */ |
| /****************************************************************************** |
| * |
| * Copyright(c) 2007 - 2010 Realtek Corporation. All rights reserved. |
| * |
| * Modifications for inclusion into the Linux staging tree are |
| * Copyright(c) 2010 Larry Finger. All rights reserved. |
| * |
| * Contact information: |
| * WLAN FAE <wlanfae@realtek.com> |
| * Larry Finger <Larry.Finger@lwfinger.net> |
| * |
| ******************************************************************************/ |
| #ifndef _RTL871X_MP_IOCTL_H |
| #define _RTL871X_MP_IOCTL_H |
| |
| #include "osdep_service.h" |
| #include "drv_types.h" |
| #include "mp_custom_oid.h" |
| #include "rtl871x_ioctl.h" |
| #include "rtl871x_ioctl_rtl.h" |
| #include "rtl8712_efuse.h" |
| |
| #define TESTFWCMDNUMBER 1000000 |
| #define TEST_H2CINT_WAIT_TIME 500 |
| #define TEST_C2HINT_WAIT_TIME 500 |
| #define HCI_TEST_SYSCFG_HWMASK 1 |
| #define _BUSCLK_40M (4 << 2) |
| |
| struct CFG_DBG_MSG_STRUCT { |
| u32 DebugLevel; |
| u32 DebugComponent_H32; |
| u32 DebugComponent_L32; |
| }; |
| |
| struct mp_rw_reg { |
| uint offset; |
| uint width; |
| u32 value; |
| }; |
| |
| /* for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM */ |
| struct eeprom_rw_param { |
| uint offset; |
| u16 value; |
| }; |
| |
| struct EFUSE_ACCESS_STRUCT { |
| u16 start_addr; |
| u16 cnts; |
| u8 data[]; |
| }; |
| |
| struct burst_rw_reg { |
| uint offset; |
| uint len; |
| u8 Data[256]; |
| }; |
| |
| struct usb_vendor_req { |
| u8 bRequest; |
| u16 wValue; |
| u16 wIndex; |
| u16 wLength; |
| u8 u8Dir;/*0:OUT, 1:IN */ |
| u8 u8InData; |
| }; |
| |
| struct DR_VARIABLE_STRUCT { |
| u8 offset; |
| u32 variable; |
| }; |
| |
| /* oid_rtl_seg_87_11_00 */ |
| uint oid_rt_pro_read_register_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_write_register_hdl(struct oid_par_priv *poid_par_priv); |
| /* oid_rtl_seg_81_80_00 */ |
| uint oid_rt_pro_set_data_rate_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_channel_direct_call_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_antenna_bb_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_tx_power_control_hdl( |
| struct oid_par_priv *poid_par_priv); |
| /* oid_rtl_seg_81_80_20 */ |
| uint oid_rt_pro_query_tx_packet_sent_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_query_rx_packet_received_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_query_rx_packet_crc32_error_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_reset_tx_packet_sent_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_reset_rx_packet_received_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_modulation_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_continuous_tx_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_single_carrier_tx_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_carrier_suppression_tx_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_set_single_tone_tx_hdl( |
| struct oid_par_priv *poid_par_priv); |
| /* oid_rtl_seg_81_87 */ |
| uint oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv); |
| /* oid_rtl_seg_81_85 */ |
| uint oid_rt_wireless_mode_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_get_efuse_current_size_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_efuse_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_set_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_get_efuse_max_size_hdl(struct oid_par_priv *poid_par_priv); |
| uint oid_rt_get_thermal_meter_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_reset_phy_rx_packet_count_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_get_phy_rx_packet_received_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_get_phy_rx_packet_crc32_error_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_set_power_down_hdl( |
| struct oid_par_priv *poid_par_priv); |
| uint oid_rt_get_power_mode_hdl( |
| struct oid_par_priv *poid_par_priv); |
| #ifdef _RTL871X_MP_IOCTL_C_ /* CAUTION!!! */ |
| /* This ifdef _MUST_ be left in!! */ |
| |
| #else /* _RTL871X_MP_IOCTL_C_ */ |
| extern struct oid_obj_priv oid_rtl_seg_81_87[5]; |
| extern struct oid_obj_priv oid_rtl_seg_87_11_00[32]; |
| extern struct oid_obj_priv oid_rtl_seg_87_11_20[5]; |
| extern struct oid_obj_priv oid_rtl_seg_87_11_50[2]; |
| extern struct oid_obj_priv oid_rtl_seg_87_11_80[1]; |
| extern struct oid_obj_priv oid_rtl_seg_87_11_B0[1]; |
| extern struct oid_obj_priv oid_rtl_seg_87_11_F0[16]; |
| extern struct oid_obj_priv oid_rtl_seg_87_12_00[32]; |
| |
| #endif /* _RTL871X_MP_IOCTL_C_ */ |
| |
| |
| enum MP_MODE { |
| MP_START_MODE, |
| MP_STOP_MODE, |
| MP_ERR_MODE |
| }; |
| |
| struct rwreg_param { |
| unsigned int offset; |
| unsigned int width; |
| unsigned int value; |
| }; |
| |
| struct bbreg_param { |
| unsigned int offset; |
| unsigned int phymask; |
| unsigned int value; |
| }; |
| |
| struct txpower_param { |
| unsigned int pwr_index; |
| }; |
| |
| struct datarate_param { |
| unsigned int rate_index; |
| }; |
| |
| struct rfintfs_parm { |
| unsigned int rfintfs; |
| }; |
| |
| struct mp_xmit_packet { |
| unsigned int len; |
| }; |
| |
| struct psmode_param { |
| unsigned int ps_mode; |
| unsigned int smart_ps; |
| }; |
| |
| struct mp_ioctl_handler { |
| unsigned int paramsize; |
| unsigned int (*handler)(struct oid_par_priv *poid_par_priv); |
| unsigned int oid; |
| }; |
| |
| struct mp_ioctl_param { |
| unsigned int subcode; |
| unsigned int len; |
| unsigned char data[]; |
| }; |
| |
| #define GEN_MP_IOCTL_SUBCODE(code) _MP_IOCTL_ ## code ## _CMD_ |
| |
| enum RTL871X_MP_IOCTL_SUBCODE { |
| GEN_MP_IOCTL_SUBCODE(MP_START), /*0*/ |
| GEN_MP_IOCTL_SUBCODE(MP_STOP), /*1*/ |
| GEN_MP_IOCTL_SUBCODE(READ_REG), /*2*/ |
| GEN_MP_IOCTL_SUBCODE(WRITE_REG), |
| GEN_MP_IOCTL_SUBCODE(SET_CHANNEL), /*4*/ |
| GEN_MP_IOCTL_SUBCODE(SET_TXPOWER), /*5*/ |
| GEN_MP_IOCTL_SUBCODE(SET_DATARATE), /*6*/ |
| GEN_MP_IOCTL_SUBCODE(READ_BB_REG), /*7*/ |
| GEN_MP_IOCTL_SUBCODE(WRITE_BB_REG), |
| GEN_MP_IOCTL_SUBCODE(READ_RF_REG), /*9*/ |
| GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG), |
| GEN_MP_IOCTL_SUBCODE(SET_RF_INTFS), |
| GEN_MP_IOCTL_SUBCODE(IOCTL_XMIT_PACKET), /*12*/ |
| GEN_MP_IOCTL_SUBCODE(PS_STATE), /*13*/ |
| GEN_MP_IOCTL_SUBCODE(READ16_EEPROM), /*14*/ |
| GEN_MP_IOCTL_SUBCODE(WRITE16_EEPROM), /*15*/ |
| GEN_MP_IOCTL_SUBCODE(SET_PTM), /*16*/ |
| GEN_MP_IOCTL_SUBCODE(READ_TSSI), /*17*/ |
| GEN_MP_IOCTL_SUBCODE(CNTU_TX), /*18*/ |
| GEN_MP_IOCTL_SUBCODE(SET_BANDWIDTH), /*19*/ |
| GEN_MP_IOCTL_SUBCODE(SET_RX_PKT_TYPE), /*20*/ |
| GEN_MP_IOCTL_SUBCODE(RESET_PHY_RX_PKT_CNT), /*21*/ |
| GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_RECV), /*22*/ |
| GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_ERROR), /*23*/ |
| GEN_MP_IOCTL_SUBCODE(SET_POWER_DOWN), /*24*/ |
| GEN_MP_IOCTL_SUBCODE(GET_THERMAL_METER), /*25*/ |
| GEN_MP_IOCTL_SUBCODE(GET_POWER_MODE), /*26*/ |
| GEN_MP_IOCTL_SUBCODE(EFUSE), /*27*/ |
| GEN_MP_IOCTL_SUBCODE(EFUSE_MAP), /*28*/ |
| GEN_MP_IOCTL_SUBCODE(GET_EFUSE_MAX_SIZE), /*29*/ |
| GEN_MP_IOCTL_SUBCODE(GET_EFUSE_CURRENT_SIZE), /*30*/ |
| GEN_MP_IOCTL_SUBCODE(SC_TX), /*31*/ |
| GEN_MP_IOCTL_SUBCODE(CS_TX), /*32*/ |
| GEN_MP_IOCTL_SUBCODE(ST_TX), /*33*/ |
| GEN_MP_IOCTL_SUBCODE(SET_ANTENNA), /*34*/ |
| MAX_MP_IOCTL_SUBCODE, |
| }; |
| |
| unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv); |
| |
| #ifdef _RTL871X_MP_IOCTL_C_ /* CAUTION!!! */ |
| /* This ifdef _MUST_ be left in!! */ |
| |
| static struct mp_ioctl_handler mp_ioctl_hdl[] = { |
| {sizeof(u32), oid_rt_pro_start_test_hdl, |
| OID_RT_PRO_START_TEST},/*0*/ |
| {sizeof(u32), oid_rt_pro_stop_test_hdl, |
| OID_RT_PRO_STOP_TEST},/*1*/ |
| {sizeof(struct rwreg_param), |
| oid_rt_pro_read_register_hdl, |
| OID_RT_PRO_READ_REGISTER},/*2*/ |
| {sizeof(struct rwreg_param), |
| oid_rt_pro_write_register_hdl, |
| OID_RT_PRO_WRITE_REGISTER}, |
| {sizeof(u32), |
| oid_rt_pro_set_channel_direct_call_hdl, |
| OID_RT_PRO_SET_CHANNEL_DIRECT_CALL}, |
| {sizeof(struct txpower_param), |
| oid_rt_pro_set_tx_power_control_hdl, |
| OID_RT_PRO_SET_TX_POWER_CONTROL}, |
| {sizeof(u32), |
| oid_rt_pro_set_data_rate_hdl, |
| OID_RT_PRO_SET_DATA_RATE}, |
| {sizeof(struct bb_reg_param), |
| oid_rt_pro_read_bb_reg_hdl, |
| OID_RT_PRO_READ_BB_REG},/*7*/ |
| {sizeof(struct bb_reg_param), |
| oid_rt_pro_write_bb_reg_hdl, |
| OID_RT_PRO_WRITE_BB_REG}, |
| {sizeof(struct rwreg_param), |
| oid_rt_pro_read_rf_reg_hdl, |
| OID_RT_PRO_RF_READ_REGISTRY},/*9*/ |
| {sizeof(struct rwreg_param), |
| oid_rt_pro_write_rf_reg_hdl, |
| OID_RT_PRO_RF_WRITE_REGISTRY}, |
| {sizeof(struct rfintfs_parm), NULL, 0}, |
| {0, mp_ioctl_xmit_packet_hdl, 0},/*12*/ |
| {sizeof(struct psmode_param), NULL, 0},/*13*/ |
| {sizeof(struct eeprom_rw_param), NULL, 0},/*14*/ |
| {sizeof(struct eeprom_rw_param), NULL, 0},/*15*/ |
| {sizeof(unsigned char), NULL, 0},/*16*/ |
| {sizeof(u32), NULL, 0},/*17*/ |
| {sizeof(u32), oid_rt_pro_set_continuous_tx_hdl, |
| OID_RT_PRO_SET_CONTINUOUS_TX},/*18*/ |
| {sizeof(u32), oid_rt_set_bandwidth_hdl, |
| OID_RT_SET_BANDWIDTH},/*19*/ |
| {sizeof(u32), oid_rt_set_rx_packet_type_hdl, |
| OID_RT_SET_RX_PACKET_TYPE},/*20*/ |
| {0, oid_rt_reset_phy_rx_packet_count_hdl, |
| OID_RT_RESET_PHY_RX_PACKET_COUNT},/*21*/ |
| {sizeof(u32), oid_rt_get_phy_rx_packet_received_hdl, |
| OID_RT_GET_PHY_RX_PACKET_RECEIVED},/*22*/ |
| {sizeof(u32), oid_rt_get_phy_rx_packet_crc32_error_hdl, |
| OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR},/*23*/ |
| {sizeof(unsigned char), oid_rt_set_power_down_hdl, |
| OID_RT_SET_POWER_DOWN},/*24*/ |
| {sizeof(u32), oid_rt_get_thermal_meter_hdl, |
| OID_RT_PRO_GET_THERMAL_METER},/*25*/ |
| {sizeof(u32), oid_rt_get_power_mode_hdl, |
| OID_RT_GET_POWER_MODE},/*26*/ |
| {sizeof(struct EFUSE_ACCESS_STRUCT), |
| oid_rt_pro_efuse_hdl, OID_RT_PRO_EFUSE},/*27*/ |
| {EFUSE_MAP_MAX_SIZE, oid_rt_pro_efuse_map_hdl, |
| OID_RT_PRO_EFUSE_MAP},/*28*/ |
| {sizeof(u32), oid_rt_get_efuse_max_size_hdl, |
| OID_RT_GET_EFUSE_MAX_SIZE},/*29*/ |
| {sizeof(u32), oid_rt_get_efuse_current_size_hdl, |
| OID_RT_GET_EFUSE_CURRENT_SIZE},/*30*/ |
| {sizeof(u32), oid_rt_pro_set_single_carrier_tx_hdl, |
| OID_RT_PRO_SET_SINGLE_CARRIER_TX},/*31*/ |
| {sizeof(u32), oid_rt_pro_set_carrier_suppression_tx_hdl, |
| OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX},/*32*/ |
| {sizeof(u32), oid_rt_pro_set_single_tone_tx_hdl, |
| OID_RT_PRO_SET_SINGLE_TONE_TX},/*33*/ |
| {sizeof(u32), oid_rt_pro_set_antenna_bb_hdl, |
| OID_RT_PRO_SET_ANTENNA_BB},/*34*/ |
| }; |
| |
| #else /* _RTL871X_MP_IOCTL_C_ */ |
| extern struct mp_ioctl_handler mp_ioctl_hdl[]; |
| #endif /* _RTL871X_MP_IOCTL_C_ */ |
| |
| #endif |
| |