1e24c1f86SMichael Straube /* SPDX-License-Identifier: GPL-2.0 */ 2cf3e6881SAli Bahar /****************************************************************************** 3cf3e6881SAli Bahar * 4cf3e6881SAli Bahar * Copyright(c) 2007 - 2010 Realtek Corporation. All rights reserved. 5cf3e6881SAli Bahar * 6cf3e6881SAli Bahar * Modifications for inclusion into the Linux staging tree are 7cf3e6881SAli Bahar * Copyright(c) 2010 Larry Finger. All rights reserved. 8cf3e6881SAli Bahar * 9cf3e6881SAli Bahar * Contact information: 10cf3e6881SAli Bahar * WLAN FAE <wlanfae@realtek.com> 11cf3e6881SAli Bahar * Larry Finger <Larry.Finger@lwfinger.net> 12cf3e6881SAli Bahar * 13cf3e6881SAli Bahar ******************************************************************************/ 142865d42cSLarry Finger #ifndef _RTL871X_MP_IOCTL_H 152865d42cSLarry Finger #define _RTL871X_MP_IOCTL_H 162865d42cSLarry Finger 172865d42cSLarry Finger #include "osdep_service.h" 182865d42cSLarry Finger #include "drv_types.h" 192865d42cSLarry Finger #include "mp_custom_oid.h" 202865d42cSLarry Finger #include "rtl871x_ioctl.h" 212865d42cSLarry Finger #include "rtl871x_ioctl_rtl.h" 222865d42cSLarry Finger #include "rtl8712_efuse.h" 232865d42cSLarry Finger 242865d42cSLarry Finger #define TESTFWCMDNUMBER 1000000 252865d42cSLarry Finger #define TEST_H2CINT_WAIT_TIME 500 262865d42cSLarry Finger #define TEST_C2HINT_WAIT_TIME 500 272865d42cSLarry Finger #define HCI_TEST_SYSCFG_HWMASK 1 282865d42cSLarry Finger #define _BUSCLK_40M (4 << 2) 292865d42cSLarry Finger 302865d42cSLarry Finger struct CFG_DBG_MSG_STRUCT { 312865d42cSLarry Finger u32 DebugLevel; 322865d42cSLarry Finger u32 DebugComponent_H32; 332865d42cSLarry Finger u32 DebugComponent_L32; 342865d42cSLarry Finger }; 352865d42cSLarry Finger 362865d42cSLarry Finger struct mp_rw_reg { 372865d42cSLarry Finger uint offset; 382865d42cSLarry Finger uint width; 392865d42cSLarry Finger u32 value; 402865d42cSLarry Finger }; 412865d42cSLarry Finger 422865d42cSLarry Finger /* for OID_RT_PRO_READ16_EEPROM & OID_RT_PRO_WRITE16_EEPROM */ 432865d42cSLarry Finger struct eeprom_rw_param { 442865d42cSLarry Finger uint offset; 452865d42cSLarry Finger u16 value; 462865d42cSLarry Finger }; 472865d42cSLarry Finger 482865d42cSLarry Finger struct EFUSE_ACCESS_STRUCT { 492865d42cSLarry Finger u16 start_addr; 502865d42cSLarry Finger u16 cnts; 515979afa2SGustavo A. R. Silva u8 data[]; 522865d42cSLarry Finger }; 532865d42cSLarry Finger 542865d42cSLarry Finger struct burst_rw_reg { 552865d42cSLarry Finger uint offset; 562865d42cSLarry Finger uint len; 572865d42cSLarry Finger u8 Data[256]; 582865d42cSLarry Finger }; 592865d42cSLarry Finger 602865d42cSLarry Finger struct usb_vendor_req { 612865d42cSLarry Finger u8 bRequest; 622865d42cSLarry Finger u16 wValue; 632865d42cSLarry Finger u16 wIndex; 642865d42cSLarry Finger u16 wLength; 652865d42cSLarry Finger u8 u8Dir;/*0:OUT, 1:IN */ 662865d42cSLarry Finger u8 u8InData; 672865d42cSLarry Finger }; 682865d42cSLarry Finger 692865d42cSLarry Finger struct DR_VARIABLE_STRUCT { 702865d42cSLarry Finger u8 offset; 712865d42cSLarry Finger u32 variable; 722865d42cSLarry Finger }; 732865d42cSLarry Finger 742865d42cSLarry Finger /* oid_rtl_seg_87_11_00 */ 752865d42cSLarry Finger uint oid_rt_pro_read_register_hdl(struct oid_par_priv *poid_par_priv); 762865d42cSLarry Finger uint oid_rt_pro_write_register_hdl(struct oid_par_priv *poid_par_priv); 772865d42cSLarry Finger /* oid_rtl_seg_81_80_00 */ 782865d42cSLarry Finger uint oid_rt_pro_set_data_rate_hdl( 792865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 802865d42cSLarry Finger uint oid_rt_pro_start_test_hdl(struct oid_par_priv *poid_par_priv); 812865d42cSLarry Finger uint oid_rt_pro_stop_test_hdl(struct oid_par_priv *poid_par_priv); 822865d42cSLarry Finger uint oid_rt_pro_set_channel_direct_call_hdl( 832865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 842865d42cSLarry Finger uint oid_rt_pro_set_antenna_bb_hdl( 852865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 862865d42cSLarry Finger uint oid_rt_pro_set_tx_power_control_hdl( 872865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 882865d42cSLarry Finger /* oid_rtl_seg_81_80_20 */ 892865d42cSLarry Finger uint oid_rt_pro_query_tx_packet_sent_hdl( 902865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 912865d42cSLarry Finger uint oid_rt_pro_query_rx_packet_received_hdl( 922865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 932865d42cSLarry Finger uint oid_rt_pro_query_rx_packet_crc32_error_hdl( 942865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 952865d42cSLarry Finger uint oid_rt_pro_reset_tx_packet_sent_hdl( 962865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 972865d42cSLarry Finger uint oid_rt_pro_reset_rx_packet_received_hdl( 982865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 992865d42cSLarry Finger uint oid_rt_pro_set_modulation_hdl(struct oid_par_priv *poid_par_priv); 1002865d42cSLarry Finger uint oid_rt_pro_set_continuous_tx_hdl( 1012865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1022865d42cSLarry Finger uint oid_rt_pro_set_single_carrier_tx_hdl( 1032865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1042865d42cSLarry Finger uint oid_rt_pro_set_carrier_suppression_tx_hdl( 1052865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1062865d42cSLarry Finger uint oid_rt_pro_set_single_tone_tx_hdl( 1072865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1082865d42cSLarry Finger /* oid_rtl_seg_81_87 */ 1092865d42cSLarry Finger uint oid_rt_pro_write_bb_reg_hdl(struct oid_par_priv *poid_par_priv); 1102865d42cSLarry Finger uint oid_rt_pro_read_bb_reg_hdl(struct oid_par_priv *poid_par_priv); 1112865d42cSLarry Finger uint oid_rt_pro_write_rf_reg_hdl(struct oid_par_priv *poid_par_priv); 1122865d42cSLarry Finger uint oid_rt_pro_read_rf_reg_hdl(struct oid_par_priv *poid_par_priv); 1132865d42cSLarry Finger /* oid_rtl_seg_81_85 */ 1142865d42cSLarry Finger uint oid_rt_wireless_mode_hdl(struct oid_par_priv *poid_par_priv); 1152865d42cSLarry Finger uint oid_rt_pro_read_efuse_hdl(struct oid_par_priv *poid_par_priv); 1162865d42cSLarry Finger uint oid_rt_pro_write_efuse_hdl(struct oid_par_priv *poid_par_priv); 1172865d42cSLarry Finger uint oid_rt_get_efuse_current_size_hdl( 1182865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1192865d42cSLarry Finger uint oid_rt_pro_efuse_hdl(struct oid_par_priv *poid_par_priv); 1202865d42cSLarry Finger uint oid_rt_pro_efuse_map_hdl(struct oid_par_priv *poid_par_priv); 1212865d42cSLarry Finger uint oid_rt_set_bandwidth_hdl(struct oid_par_priv *poid_par_priv); 1222865d42cSLarry Finger uint oid_rt_set_rx_packet_type_hdl(struct oid_par_priv *poid_par_priv); 1232865d42cSLarry Finger uint oid_rt_get_efuse_max_size_hdl(struct oid_par_priv *poid_par_priv); 1242865d42cSLarry Finger uint oid_rt_get_thermal_meter_hdl( 1252865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1262865d42cSLarry Finger uint oid_rt_reset_phy_rx_packet_count_hdl( 1272865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1282865d42cSLarry Finger uint oid_rt_get_phy_rx_packet_received_hdl( 1292865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1302865d42cSLarry Finger uint oid_rt_get_phy_rx_packet_crc32_error_hdl( 1312865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1322865d42cSLarry Finger uint oid_rt_set_power_down_hdl( 1332865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1342865d42cSLarry Finger uint oid_rt_get_power_mode_hdl( 1352865d42cSLarry Finger struct oid_par_priv *poid_par_priv); 1362865d42cSLarry Finger #ifdef _RTL871X_MP_IOCTL_C_ /* CAUTION!!! */ 1372865d42cSLarry Finger /* This ifdef _MUST_ be left in!! */ 1382865d42cSLarry Finger static const struct oid_obj_priv oid_rtl_seg_81_80_00[] = { 1394c3ff837SDerek Robson /* 0x00 OID_RT_PRO_RESET_DUT */ 1404c3ff837SDerek Robson {1, oid_null_function}, 1414c3ff837SDerek Robson /* 0x01 */ 1424c3ff837SDerek Robson {1, oid_rt_pro_set_data_rate_hdl}, 1434c3ff837SDerek Robson /* 0x02 */ 1444c3ff837SDerek Robson {1, oid_rt_pro_start_test_hdl}, 1454c3ff837SDerek Robson /* 0x03 */ 1464c3ff837SDerek Robson {1, oid_rt_pro_stop_test_hdl}, 1474c3ff837SDerek Robson /* 0x04 OID_RT_PRO_SET_PREAMBLE */ 1484c3ff837SDerek Robson {1, oid_null_function}, 1494c3ff837SDerek Robson /* 0x05 OID_RT_PRO_SET_SCRAMBLER */ 1504c3ff837SDerek Robson {1, oid_null_function}, 1514c3ff837SDerek Robson /* 0x06 OID_RT_PRO_SET_FILTER_BB */ 1524c3ff837SDerek Robson {1, oid_null_function}, 1534c3ff837SDerek Robson /* 0x07 OID_RT_PRO_SET_MANUAL_DIVERS_BB */ 1544c3ff837SDerek Robson {1, oid_null_function}, 1554c3ff837SDerek Robson /* 0x08 */ 1564c3ff837SDerek Robson {1, oid_rt_pro_set_channel_direct_call_hdl}, 1574c3ff837SDerek Robson /* 0x09 OID_RT_PRO_SET_SLEEP_MODE_DIRECT_CALL */ 1584c3ff837SDerek Robson {1, oid_null_function}, 1594c3ff837SDerek Robson /* 0x0A OID_RT_PRO_SET_WAKE_MODE_DIRECT_CALL */ 1604c3ff837SDerek Robson {1, oid_null_function}, 1614c3ff837SDerek Robson /* 0x0B OID_RT_PRO_SET_TX_CONTINUOUS_DIRECT_CALL */ 1624c3ff837SDerek Robson {1, oid_rt_pro_set_continuous_tx_hdl}, 1634c3ff837SDerek Robson /* 0x0C OID_RT_PRO_SET_SINGLE_CARRIER_TX_CONTINUOUS */ 1644c3ff837SDerek Robson {1, oid_rt_pro_set_single_carrier_tx_hdl}, 1654c3ff837SDerek Robson /* 0x0D OID_RT_PRO_SET_TX_ANTENNA_BB */ 1664c3ff837SDerek Robson {1, oid_null_function}, 1674c3ff837SDerek Robson /* 0x0E */ 1684c3ff837SDerek Robson {1, oid_rt_pro_set_antenna_bb_hdl}, 1694c3ff837SDerek Robson /* 0x0F OID_RT_PRO_SET_CR_SCRAMBLER */ 1704c3ff837SDerek Robson {1, oid_null_function}, 1714c3ff837SDerek Robson /* 0x10 OID_RT_PRO_SET_CR_NEW_FILTER */ 1724c3ff837SDerek Robson {1, oid_null_function}, 1734c3ff837SDerek Robson /* 0x11 OID_RT_PRO_SET_TX_POWER_CONTROL */ 1744c3ff837SDerek Robson {1, oid_rt_pro_set_tx_power_control_hdl}, 1754c3ff837SDerek Robson /* 0x12 OID_RT_PRO_SET_CR_TX_CONFIG */ 1764c3ff837SDerek Robson {1, oid_null_function}, 1774c3ff837SDerek Robson /* 0x13 OID_RT_PRO_GET_TX_POWER_CONTROL */ 1784c3ff837SDerek Robson {1, oid_null_function}, 1794c3ff837SDerek Robson /* 0x14 OID_RT_PRO_GET_CR_SIGNAL_QUALITY */ 1804c3ff837SDerek Robson {1, oid_null_function}, 1814c3ff837SDerek Robson /* 0x15 OID_RT_PRO_SET_CR_SETPOINT */ 1824c3ff837SDerek Robson {1, oid_null_function}, 1834c3ff837SDerek Robson /* 0x16 OID_RT_PRO_SET_INTEGRATOR */ 1844c3ff837SDerek Robson {1, oid_null_function}, 1854c3ff837SDerek Robson /* 0x17 OID_RT_PRO_SET_SIGNAL_QUALITY */ 1864c3ff837SDerek Robson {1, oid_null_function}, 1874c3ff837SDerek Robson /* 0x18 OID_RT_PRO_GET_INTEGRATOR */ 1884c3ff837SDerek Robson {1, oid_null_function}, 1894c3ff837SDerek Robson /* 0x19 OID_RT_PRO_GET_SIGNAL_QUALITY */ 1904c3ff837SDerek Robson {1, oid_null_function}, 1914c3ff837SDerek Robson /* 0x1A OID_RT_PRO_QUERY_EEPROM_TYPE */ 1924c3ff837SDerek Robson {1, oid_null_function}, 1934c3ff837SDerek Robson /* 0x1B OID_RT_PRO_WRITE_MAC_ADDRESS */ 1944c3ff837SDerek Robson {1, oid_null_function}, 1954c3ff837SDerek Robson /* 0x1C OID_RT_PRO_READ_MAC_ADDRESS */ 1964c3ff837SDerek Robson {1, oid_null_function}, 1974c3ff837SDerek Robson /* 0x1D OID_RT_PRO_WRITE_CIS_DATA */ 1984c3ff837SDerek Robson {1, oid_null_function}, 1994c3ff837SDerek Robson /* 0x1E OID_RT_PRO_READ_CIS_DATA */ 2004c3ff837SDerek Robson {1, oid_null_function}, 2014c3ff837SDerek Robson /* 0x1F OID_RT_PRO_WRITE_POWER_CONTROL */ 2024c3ff837SDerek Robson {1, oid_null_function} 2032865d42cSLarry Finger }; 2042865d42cSLarry Finger 2052865d42cSLarry Finger static const struct oid_obj_priv oid_rtl_seg_81_80_20[] = { 2064c3ff837SDerek Robson /* 0x20 OID_RT_PRO_READ_POWER_CONTROL */ 2074c3ff837SDerek Robson {1, oid_null_function}, 2084c3ff837SDerek Robson /* 0x21 OID_RT_PRO_WRITE_EEPROM */ 2094c3ff837SDerek Robson {1, oid_null_function}, 2104c3ff837SDerek Robson /* 0x22 OID_RT_PRO_READ_EEPROM */ 2114c3ff837SDerek Robson {1, oid_null_function}, 2124c3ff837SDerek Robson /* 0x23 */ 2134c3ff837SDerek Robson {1, oid_rt_pro_reset_tx_packet_sent_hdl}, 2144c3ff837SDerek Robson /* 0x24 */ 2154c3ff837SDerek Robson {1, oid_rt_pro_query_tx_packet_sent_hdl}, 2164c3ff837SDerek Robson /* 0x25 */ 2174c3ff837SDerek Robson {1, oid_rt_pro_reset_rx_packet_received_hdl}, 2184c3ff837SDerek Robson /* 0x26 */ 2194c3ff837SDerek Robson {1, oid_rt_pro_query_rx_packet_received_hdl}, 2204c3ff837SDerek Robson /* 0x27 */ 2214c3ff837SDerek Robson {1, oid_rt_pro_query_rx_packet_crc32_error_hdl}, 2224c3ff837SDerek Robson /* 0x28 OID_RT_PRO_QUERY_CURRENT_ADDRESS */ 2234c3ff837SDerek Robson {1, oid_null_function}, 2244c3ff837SDerek Robson /* 0x29 OID_RT_PRO_QUERY_PERMANENT_ADDRESS */ 2254c3ff837SDerek Robson {1, oid_null_function}, 2264c3ff837SDerek Robson /* 0x2A OID_RT_PRO_SET_PHILIPS_RF_PARAMETERS */ 2274c3ff837SDerek Robson {1, oid_null_function}, 2284c3ff837SDerek Robson /* 0x2B OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX */ 2294c3ff837SDerek Robson {1, oid_rt_pro_set_carrier_suppression_tx_hdl}, 2304c3ff837SDerek Robson /* 0x2C OID_RT_PRO_RECEIVE_PACKET */ 2314c3ff837SDerek Robson {1, oid_null_function}, 2324c3ff837SDerek Robson /* 0x2D OID_RT_PRO_WRITE_EEPROM_BYTE */ 2334c3ff837SDerek Robson {1, oid_null_function}, 2344c3ff837SDerek Robson /* 0x2E OID_RT_PRO_READ_EEPROM_BYTE */ 2354c3ff837SDerek Robson {1, oid_null_function}, 2364c3ff837SDerek Robson /* 0x2F */ 2374c3ff837SDerek Robson {1, oid_rt_pro_set_modulation_hdl} 2382865d42cSLarry Finger }; 2392865d42cSLarry Finger 2402865d42cSLarry Finger static const struct oid_obj_priv oid_rtl_seg_81_80_40[] = { 241bce2fc58SAmitoj Kaur Chawla {1, oid_null_function}, /* 0x40 */ 242bce2fc58SAmitoj Kaur Chawla {1, oid_null_function}, /* 0x41 */ 243bce2fc58SAmitoj Kaur Chawla {1, oid_null_function}, /* 0x42 */ 244bce2fc58SAmitoj Kaur Chawla {1, oid_rt_pro_set_single_tone_tx_hdl}, /* 0x43 */ 245bce2fc58SAmitoj Kaur Chawla {1, oid_null_function}, /* 0x44 */ 246bce2fc58SAmitoj Kaur Chawla {1, oid_null_function} /* 0x45 */ 2472865d42cSLarry Finger }; 2482865d42cSLarry Finger 2492865d42cSLarry Finger static const struct oid_obj_priv oid_rtl_seg_81_80_80[] = { 250bce2fc58SAmitoj Kaur Chawla {1, oid_null_function}, /* 0x80 OID_RT_DRIVER_OPTION */ 251bce2fc58SAmitoj Kaur Chawla {1, oid_null_function}, /* 0x81 OID_RT_RF_OFF */ 252bce2fc58SAmitoj Kaur Chawla {1, oid_null_function} /* 0x82 OID_RT_AUTH_STATUS */ 2532865d42cSLarry Finger 2542865d42cSLarry Finger }; 2552865d42cSLarry Finger 2562865d42cSLarry Finger static const struct oid_obj_priv oid_rtl_seg_81_85[] = { 2574c3ff837SDerek Robson /* 0x00 OID_RT_WIRELESS_MODE */ 2584c3ff837SDerek Robson {1, oid_rt_wireless_mode_hdl} 2592865d42cSLarry Finger }; 2602865d42cSLarry Finger 2612865d42cSLarry Finger #else /* _RTL871X_MP_IOCTL_C_ */ 2622865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_81_80_00[32]; 2632865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_81_80_20[16]; 2642865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_81_80_40[6]; 2652865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_81_80_80[3]; 2662865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_81_85[1]; 2672865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_81_87[5]; 2682865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_11_00[32]; 2692865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_11_20[5]; 2702865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_11_50[2]; 2712865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_11_80[1]; 2722865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_11_B0[1]; 2732865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_11_F0[16]; 2742865d42cSLarry Finger extern struct oid_obj_priv oid_rtl_seg_87_12_00[32]; 2752865d42cSLarry Finger 2762865d42cSLarry Finger #endif /* _RTL871X_MP_IOCTL_C_ */ 2772865d42cSLarry Finger 2782865d42cSLarry Finger 2792865d42cSLarry Finger enum MP_MODE { 2802865d42cSLarry Finger MP_START_MODE, 2812865d42cSLarry Finger MP_STOP_MODE, 2822865d42cSLarry Finger MP_ERR_MODE 2832865d42cSLarry Finger }; 2842865d42cSLarry Finger 2852865d42cSLarry Finger struct rwreg_param { 2862865d42cSLarry Finger unsigned int offset; 2872865d42cSLarry Finger unsigned int width; 2882865d42cSLarry Finger unsigned int value; 2892865d42cSLarry Finger }; 2902865d42cSLarry Finger 2912865d42cSLarry Finger struct bbreg_param { 2922865d42cSLarry Finger unsigned int offset; 2932865d42cSLarry Finger unsigned int phymask; 2942865d42cSLarry Finger unsigned int value; 2952865d42cSLarry Finger }; 2962865d42cSLarry Finger 2972865d42cSLarry Finger struct txpower_param { 2982865d42cSLarry Finger unsigned int pwr_index; 2992865d42cSLarry Finger }; 3002865d42cSLarry Finger 3012865d42cSLarry Finger struct datarate_param { 3022865d42cSLarry Finger unsigned int rate_index; 3032865d42cSLarry Finger }; 3042865d42cSLarry Finger 3052865d42cSLarry Finger struct rfintfs_parm { 3062865d42cSLarry Finger unsigned int rfintfs; 3072865d42cSLarry Finger }; 3082865d42cSLarry Finger 3092865d42cSLarry Finger struct mp_xmit_packet { 3102865d42cSLarry Finger unsigned int len; 3112865d42cSLarry Finger }; 3122865d42cSLarry Finger 3132865d42cSLarry Finger struct psmode_param { 3142865d42cSLarry Finger unsigned int ps_mode; 3152865d42cSLarry Finger unsigned int smart_ps; 3162865d42cSLarry Finger }; 3172865d42cSLarry Finger 3182865d42cSLarry Finger struct mp_ioctl_handler { 3192865d42cSLarry Finger unsigned int paramsize; 3202865d42cSLarry Finger unsigned int (*handler)(struct oid_par_priv *poid_par_priv); 3212865d42cSLarry Finger unsigned int oid; 3222865d42cSLarry Finger }; 3232865d42cSLarry Finger 3242865d42cSLarry Finger struct mp_ioctl_param { 3252865d42cSLarry Finger unsigned int subcode; 3262865d42cSLarry Finger unsigned int len; 3275979afa2SGustavo A. R. Silva unsigned char data[]; 3282865d42cSLarry Finger }; 3292865d42cSLarry Finger 3302865d42cSLarry Finger #define GEN_MP_IOCTL_SUBCODE(code) _MP_IOCTL_ ## code ## _CMD_ 3312865d42cSLarry Finger 3322865d42cSLarry Finger enum RTL871X_MP_IOCTL_SUBCODE { 3332865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(MP_START), /*0*/ 3342865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(MP_STOP), /*1*/ 3352865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(READ_REG), /*2*/ 3362865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(WRITE_REG), 3372865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_CHANNEL), /*4*/ 3382865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_TXPOWER), /*5*/ 3392865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_DATARATE), /*6*/ 3402865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(READ_BB_REG), /*7*/ 3412865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(WRITE_BB_REG), 3422865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(READ_RF_REG), /*9*/ 3432865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(WRITE_RF_REG), 3442865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_RF_INTFS), 3452865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(IOCTL_XMIT_PACKET), /*12*/ 3462865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(PS_STATE), /*13*/ 3472865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(READ16_EEPROM), /*14*/ 3482865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(WRITE16_EEPROM), /*15*/ 3492865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_PTM), /*16*/ 3502865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(READ_TSSI), /*17*/ 3512865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(CNTU_TX), /*18*/ 3522865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_BANDWIDTH), /*19*/ 3532865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_RX_PKT_TYPE), /*20*/ 3542865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(RESET_PHY_RX_PKT_CNT), /*21*/ 3552865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_RECV), /*22*/ 3562865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(GET_PHY_RX_PKT_ERROR), /*23*/ 3572865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_POWER_DOWN), /*24*/ 3582865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(GET_THERMAL_METER), /*25*/ 3592865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(GET_POWER_MODE), /*26*/ 3602865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(EFUSE), /*27*/ 3612865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(EFUSE_MAP), /*28*/ 3622865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(GET_EFUSE_MAX_SIZE), /*29*/ 3632865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(GET_EFUSE_CURRENT_SIZE), /*30*/ 3642865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SC_TX), /*31*/ 3652865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(CS_TX), /*32*/ 3662865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(ST_TX), /*33*/ 3672865d42cSLarry Finger GEN_MP_IOCTL_SUBCODE(SET_ANTENNA), /*34*/ 3682865d42cSLarry Finger MAX_MP_IOCTL_SUBCODE, 3692865d42cSLarry Finger }; 3702865d42cSLarry Finger 3712865d42cSLarry Finger unsigned int mp_ioctl_xmit_packet_hdl(struct oid_par_priv *poid_par_priv); 3722865d42cSLarry Finger 3732865d42cSLarry Finger #ifdef _RTL871X_MP_IOCTL_C_ /* CAUTION!!! */ 3742865d42cSLarry Finger /* This ifdef _MUST_ be left in!! */ 3752865d42cSLarry Finger 376e3dc896bSLarry Finger static struct mp_ioctl_handler mp_ioctl_hdl[] = { 3772865d42cSLarry Finger {sizeof(u32), oid_rt_pro_start_test_hdl, 3782865d42cSLarry Finger OID_RT_PRO_START_TEST},/*0*/ 3792865d42cSLarry Finger {sizeof(u32), oid_rt_pro_stop_test_hdl, 3802865d42cSLarry Finger OID_RT_PRO_STOP_TEST},/*1*/ 3812865d42cSLarry Finger {sizeof(struct rwreg_param), 3822865d42cSLarry Finger oid_rt_pro_read_register_hdl, 3832865d42cSLarry Finger OID_RT_PRO_READ_REGISTER},/*2*/ 3842865d42cSLarry Finger {sizeof(struct rwreg_param), 3852865d42cSLarry Finger oid_rt_pro_write_register_hdl, 3862865d42cSLarry Finger OID_RT_PRO_WRITE_REGISTER}, 3872865d42cSLarry Finger {sizeof(u32), 3882865d42cSLarry Finger oid_rt_pro_set_channel_direct_call_hdl, 3892865d42cSLarry Finger OID_RT_PRO_SET_CHANNEL_DIRECT_CALL}, 3902865d42cSLarry Finger {sizeof(struct txpower_param), 3912865d42cSLarry Finger oid_rt_pro_set_tx_power_control_hdl, 3922865d42cSLarry Finger OID_RT_PRO_SET_TX_POWER_CONTROL}, 3932865d42cSLarry Finger {sizeof(u32), 3942865d42cSLarry Finger oid_rt_pro_set_data_rate_hdl, 3952865d42cSLarry Finger OID_RT_PRO_SET_DATA_RATE}, 3962865d42cSLarry Finger {sizeof(struct bb_reg_param), 3972865d42cSLarry Finger oid_rt_pro_read_bb_reg_hdl, 3982865d42cSLarry Finger OID_RT_PRO_READ_BB_REG},/*7*/ 3992865d42cSLarry Finger {sizeof(struct bb_reg_param), 4002865d42cSLarry Finger oid_rt_pro_write_bb_reg_hdl, 4012865d42cSLarry Finger OID_RT_PRO_WRITE_BB_REG}, 4022865d42cSLarry Finger {sizeof(struct rwreg_param), 4032865d42cSLarry Finger oid_rt_pro_read_rf_reg_hdl, 4042865d42cSLarry Finger OID_RT_PRO_RF_READ_REGISTRY},/*9*/ 4052865d42cSLarry Finger {sizeof(struct rwreg_param), 4062865d42cSLarry Finger oid_rt_pro_write_rf_reg_hdl, 4072865d42cSLarry Finger OID_RT_PRO_RF_WRITE_REGISTRY}, 4082865d42cSLarry Finger {sizeof(struct rfintfs_parm), NULL, 0}, 409bce2fc58SAmitoj Kaur Chawla {0, mp_ioctl_xmit_packet_hdl, 0},/*12*/ 4102865d42cSLarry Finger {sizeof(struct psmode_param), NULL, 0},/*13*/ 4112865d42cSLarry Finger {sizeof(struct eeprom_rw_param), NULL, 0},/*14*/ 4122865d42cSLarry Finger {sizeof(struct eeprom_rw_param), NULL, 0},/*15*/ 413ac9bfc14SAli Bahar {sizeof(unsigned char), NULL, 0},/*16*/ 4142865d42cSLarry Finger {sizeof(u32), NULL, 0},/*17*/ 4152865d42cSLarry Finger {sizeof(u32), oid_rt_pro_set_continuous_tx_hdl, 4162865d42cSLarry Finger OID_RT_PRO_SET_CONTINUOUS_TX},/*18*/ 4172865d42cSLarry Finger {sizeof(u32), oid_rt_set_bandwidth_hdl, 4182865d42cSLarry Finger OID_RT_SET_BANDWIDTH},/*19*/ 4192865d42cSLarry Finger {sizeof(u32), oid_rt_set_rx_packet_type_hdl, 4202865d42cSLarry Finger OID_RT_SET_RX_PACKET_TYPE},/*20*/ 4212865d42cSLarry Finger {0, oid_rt_reset_phy_rx_packet_count_hdl, 4222865d42cSLarry Finger OID_RT_RESET_PHY_RX_PACKET_COUNT},/*21*/ 4232865d42cSLarry Finger {sizeof(u32), oid_rt_get_phy_rx_packet_received_hdl, 4242865d42cSLarry Finger OID_RT_GET_PHY_RX_PACKET_RECEIVED},/*22*/ 4252865d42cSLarry Finger {sizeof(u32), oid_rt_get_phy_rx_packet_crc32_error_hdl, 4262865d42cSLarry Finger OID_RT_GET_PHY_RX_PACKET_CRC32_ERROR},/*23*/ 4272865d42cSLarry Finger {sizeof(unsigned char), oid_rt_set_power_down_hdl, 4282865d42cSLarry Finger OID_RT_SET_POWER_DOWN},/*24*/ 4292865d42cSLarry Finger {sizeof(u32), oid_rt_get_thermal_meter_hdl, 4302865d42cSLarry Finger OID_RT_PRO_GET_THERMAL_METER},/*25*/ 4312865d42cSLarry Finger {sizeof(u32), oid_rt_get_power_mode_hdl, 4322865d42cSLarry Finger OID_RT_GET_POWER_MODE},/*26*/ 4332865d42cSLarry Finger {sizeof(struct EFUSE_ACCESS_STRUCT), 4342865d42cSLarry Finger oid_rt_pro_efuse_hdl, OID_RT_PRO_EFUSE},/*27*/ 4352865d42cSLarry Finger {EFUSE_MAP_MAX_SIZE, oid_rt_pro_efuse_map_hdl, 4362865d42cSLarry Finger OID_RT_PRO_EFUSE_MAP},/*28*/ 4372865d42cSLarry Finger {sizeof(u32), oid_rt_get_efuse_max_size_hdl, 4382865d42cSLarry Finger OID_RT_GET_EFUSE_MAX_SIZE},/*29*/ 4392865d42cSLarry Finger {sizeof(u32), oid_rt_get_efuse_current_size_hdl, 4402865d42cSLarry Finger OID_RT_GET_EFUSE_CURRENT_SIZE},/*30*/ 4412865d42cSLarry Finger {sizeof(u32), oid_rt_pro_set_single_carrier_tx_hdl, 4422865d42cSLarry Finger OID_RT_PRO_SET_SINGLE_CARRIER_TX},/*31*/ 4432865d42cSLarry Finger {sizeof(u32), oid_rt_pro_set_carrier_suppression_tx_hdl, 4442865d42cSLarry Finger OID_RT_PRO_SET_CARRIER_SUPPRESSION_TX},/*32*/ 4452865d42cSLarry Finger {sizeof(u32), oid_rt_pro_set_single_tone_tx_hdl, 4462865d42cSLarry Finger OID_RT_PRO_SET_SINGLE_TONE_TX},/*33*/ 4472865d42cSLarry Finger {sizeof(u32), oid_rt_pro_set_antenna_bb_hdl, 4482865d42cSLarry Finger OID_RT_PRO_SET_ANTENNA_BB},/*34*/ 4492865d42cSLarry Finger }; 4502865d42cSLarry Finger 4512865d42cSLarry Finger #else /* _RTL871X_MP_IOCTL_C_ */ 4522865d42cSLarry Finger extern struct mp_ioctl_handler mp_ioctl_hdl[]; 4532865d42cSLarry Finger #endif /* _RTL871X_MP_IOCTL_C_ */ 4542865d42cSLarry Finger 4552865d42cSLarry Finger #endif 4562865d42cSLarry Finger 457