1 /* 2 * Common function shared by Linux WEXT, cfg80211 and p2p drivers 3 * 4 * Copyright (C) 1999-2013, Broadcom Corporation 5 * 6 * Unless you and Broadcom execute a separate written software license 7 * agreement governing use of this software, this software is licensed to you 8 * under the terms of the GNU General Public License version 2 (the "GPL"), 9 * available at http://www.broadcom.com/licenses/GPLv2.php, with the 10 * following added to such license: 11 * 12 * As a special exception, the copyright holders of this software give you 13 * permission to link this software with independent modules, and to copy and 14 * distribute the resulting executable under terms of your choice, provided that 15 * you also meet, for each linked independent module, the terms and conditions of 16 * the license of that module. An independent module is a module which is not 17 * derived from this software. The special exception does not apply to any 18 * modifications of the software. 19 * 20 * Notwithstanding the above, under no circumstances may you combine this 21 * software in any way with any other Broadcom software provided under a license 22 * other than the GPL, without Broadcom's express prior written consent. 23 * 24 * $Id: wldev_common.h,v 1.1.4.1.2.14 2011-02-09 01:40:07 $ 25 */ 26 #ifndef __WLDEV_COMMON_H__ 27 #define __WLDEV_COMMON_H__ 28 29 #include <wlioctl.h> 30 31 /* wl_dev_ioctl - get/set IOCTLs, will call net_device's do_ioctl (or 32 * netdev_ops->ndo_do_ioctl in new kernels) 33 * @dev: the net_device handle 34 */ 35 s32 wldev_ioctl( 36 struct net_device *dev, u32 cmd, void *arg, u32 len, u32 set); 37 38 /** Retrieve named IOVARs, this function calls wl_dev_ioctl with 39 * WLC_GET_VAR IOCTL code 40 */ 41 s32 wldev_iovar_getbuf( 42 struct net_device *dev, s8 *iovar_name, 43 void *param, s32 paramlen, void *buf, s32 buflen, struct mutex* buf_sync); 44 45 /** Set named IOVARs, this function calls wl_dev_ioctl with 46 * WLC_SET_VAR IOCTL code 47 */ 48 s32 wldev_iovar_setbuf( 49 struct net_device *dev, s8 *iovar_name, 50 void *param, s32 paramlen, void *buf, s32 buflen, struct mutex* buf_sync); 51 52 s32 wldev_iovar_setint( 53 struct net_device *dev, s8 *iovar, s32 val); 54 55 s32 wldev_iovar_getint( 56 struct net_device *dev, s8 *iovar, s32 *pval); 57 58 /** The following function can be implemented if there is a need for bsscfg 59 * indexed IOVARs 60 */ 61 62 s32 wldev_mkiovar_bsscfg( 63 const s8 *iovar_name, s8 *param, s32 paramlen, 64 s8 *iovar_buf, s32 buflen, s32 bssidx); 65 66 /** Retrieve named and bsscfg indexed IOVARs, this function calls wl_dev_ioctl with 67 * WLC_GET_VAR IOCTL code 68 */ 69 s32 wldev_iovar_getbuf_bsscfg( 70 struct net_device *dev, s8 *iovar_name, void *param, s32 paramlen, 71 void *buf, s32 buflen, s32 bsscfg_idx, struct mutex* buf_sync); 72 73 /** Set named and bsscfg indexed IOVARs, this function calls wl_dev_ioctl with 74 * WLC_SET_VAR IOCTL code 75 */ 76 s32 wldev_iovar_setbuf_bsscfg( 77 struct net_device *dev, s8 *iovar_name, void *param, s32 paramlen, 78 void *buf, s32 buflen, s32 bsscfg_idx, struct mutex* buf_sync); 79 80 s32 wldev_iovar_getint_bsscfg( 81 struct net_device *dev, s8 *iovar, s32 *pval, s32 bssidx); 82 83 s32 wldev_iovar_setint_bsscfg( 84 struct net_device *dev, s8 *iovar, s32 val, s32 bssidx); 85 86 extern void get_customized_country_code(char *country_iso_code, wl_country_t *cspec); 87 extern void dhd_bus_country_set(struct net_device *dev, wl_country_t *cspec, bool notify); 88 extern void dhd_bus_band_set(struct net_device *dev, uint band); 89 extern int wldev_set_country(struct net_device *dev, char *country_code, bool notify, 90 bool user_enforced); 91 extern int net_os_wake_lock(struct net_device *dev); 92 extern int net_os_wake_unlock(struct net_device *dev); 93 extern int net_os_wake_lock_timeout(struct net_device *dev); 94 extern int net_os_wake_lock_timeout_enable(struct net_device *dev, int val); 95 extern int net_os_set_dtim_skip(struct net_device *dev, int val); 96 extern int net_os_set_suspend_disable(struct net_device *dev, int val); 97 extern int net_os_set_suspend(struct net_device *dev, int val, int force); 98 extern int wl_iw_parse_ssid_list_tlv(char** list_str, wlc_ssid_ext_t* ssid, 99 int max, int *bytes_left); 100 101 /* Get the link speed from dongle, speed is in kpbs */ 102 int wldev_get_link_speed(struct net_device *dev, int *plink_speed); 103 104 int wldev_get_rssi(struct net_device *dev, int *prssi); 105 106 int wldev_get_ssid(struct net_device *dev, wlc_ssid_t *pssid); 107 108 int wldev_get_band(struct net_device *dev, uint *pband); 109 110 int wldev_set_band(struct net_device *dev, uint band); 111 112 #endif /* __WLDEV_COMMON_H__ */ 113