Commit 8973a6e7 authored by Randy Dunlap's avatar Randy Dunlap Committed by John W. Linville

libertas: use kernel-doc notation, fix comment style

Convert all libertas/ files to use kernel-doc notation instead
of whatever it was (doxygen?).

Add or fix function parameters in several places.

Use expected style for multi-line comments in lots of places.

Remove erroneous /** in multiple places.
Signed-off-by: default avatarRandy Dunlap <randy.dunlap@oracle.com>
Acked-by: default avatarDan Williams <dcbw@redhat.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 47684808
...@@ -122,8 +122,10 @@ static u8 lbs_auth_to_authtype(enum nl80211_auth_type auth_type) ...@@ -122,8 +122,10 @@ static u8 lbs_auth_to_authtype(enum nl80211_auth_type auth_type)
} }
/* Various firmware commands need the list of supported rates, but with /*
the hight-bit set for basic rates */ * Various firmware commands need the list of supported rates, but with
* the hight-bit set for basic rates
*/
static int lbs_add_rates(u8 *rates) static int lbs_add_rates(u8 *rates)
{ {
size_t i; size_t i;
...@@ -425,7 +427,7 @@ static int lbs_add_wpa_tlv(u8 *tlv, const u8 *ie, u8 ie_len) ...@@ -425,7 +427,7 @@ static int lbs_add_wpa_tlv(u8 *tlv, const u8 *ie, u8 ie_len)
return ie_len + 2; return ie_len + 2;
} }
/*************************************************************************** /*
* Set Channel * Set Channel
*/ */
...@@ -452,7 +454,7 @@ static int lbs_cfg_set_channel(struct wiphy *wiphy, ...@@ -452,7 +454,7 @@ static int lbs_cfg_set_channel(struct wiphy *wiphy,
/*************************************************************************** /*
* Scanning * Scanning
*/ */
...@@ -538,8 +540,10 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy, ...@@ -538,8 +540,10 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy,
goto done; goto done;
} }
/* Validity check: the TLV holds TSF values with 8 bytes each, so /*
* the size in the TLV must match the nr_sets value */ * Validity check: the TLV holds TSF values with 8 bytes each, so
* the size in the TLV must match the nr_sets value
*/
i = get_unaligned_le16(tsfdesc); i = get_unaligned_le16(tsfdesc);
tsfdesc += 2; tsfdesc += 2;
if (i / 8 != scanresp->nr_sets) { if (i / 8 != scanresp->nr_sets) {
...@@ -581,8 +585,10 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy, ...@@ -581,8 +585,10 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy,
/* To find out the channel, we must parse the IEs */ /* To find out the channel, we must parse the IEs */
ie = pos; ie = pos;
/* 6+1+8+2+2: size of BSSID, RSSI, time stamp, beacon /*
interval, capabilities */ * 6+1+8+2+2: size of BSSID, RSSI, time stamp, beacon
* interval, capabilities
*/
ielen = left = len - (6 + 1 + 8 + 2 + 2); ielen = left = len - (6 + 1 + 8 + 2 + 2);
while (left >= 2) { while (left >= 2) {
u8 id, elen; u8 id, elen;
...@@ -790,7 +796,7 @@ static int lbs_cfg_scan(struct wiphy *wiphy, ...@@ -790,7 +796,7 @@ static int lbs_cfg_scan(struct wiphy *wiphy,
/*************************************************************************** /*
* Events * Events
*/ */
...@@ -825,7 +831,7 @@ void lbs_send_mic_failureevent(struct lbs_private *priv, u32 event) ...@@ -825,7 +831,7 @@ void lbs_send_mic_failureevent(struct lbs_private *priv, u32 event)
/*************************************************************************** /*
* Connect/disconnect * Connect/disconnect
*/ */
...@@ -950,8 +956,10 @@ static int lbs_enable_rsn(struct lbs_private *priv, int enable) ...@@ -950,8 +956,10 @@ static int lbs_enable_rsn(struct lbs_private *priv, int enable)
* Set WPA/WPA key material * Set WPA/WPA key material
*/ */
/* like "struct cmd_ds_802_11_key_material", but with cmd_header. Once we /*
* get rid of WEXT, this should go into host.h */ * like "struct cmd_ds_802_11_key_material", but with cmd_header. Once we
* get rid of WEXT, this should go into host.h
*/
struct cmd_key_material { struct cmd_key_material {
struct cmd_header hdr; struct cmd_header hdr;
...@@ -1536,7 +1544,7 @@ static int lbs_cfg_del_key(struct wiphy *wiphy, struct net_device *netdev, ...@@ -1536,7 +1544,7 @@ static int lbs_cfg_del_key(struct wiphy *wiphy, struct net_device *netdev,
} }
/*************************************************************************** /*
* Get station * Get station
*/ */
...@@ -1581,7 +1589,7 @@ static int lbs_cfg_get_station(struct wiphy *wiphy, struct net_device *dev, ...@@ -1581,7 +1589,7 @@ static int lbs_cfg_get_station(struct wiphy *wiphy, struct net_device *dev,
/*************************************************************************** /*
* "Site survey", here just current channel and noise level * "Site survey", here just current channel and noise level
*/ */
...@@ -1614,7 +1622,7 @@ static int lbs_get_survey(struct wiphy *wiphy, struct net_device *dev, ...@@ -1614,7 +1622,7 @@ static int lbs_get_survey(struct wiphy *wiphy, struct net_device *dev,
/*************************************************************************** /*
* Change interface * Change interface
*/ */
...@@ -1656,11 +1664,12 @@ static int lbs_change_intf(struct wiphy *wiphy, struct net_device *dev, ...@@ -1656,11 +1664,12 @@ static int lbs_change_intf(struct wiphy *wiphy, struct net_device *dev,
/*************************************************************************** /*
* IBSS (Ad-Hoc) * IBSS (Ad-Hoc)
*/ */
/* The firmware needs the following bits masked out of the beacon-derived /*
* The firmware needs the following bits masked out of the beacon-derived
* capability field when associating/joining to a BSS: * capability field when associating/joining to a BSS:
* 9 (QoS), 11 (APSD), 12 (unused), 14 (unused), 15 (unused) * 9 (QoS), 11 (APSD), 12 (unused), 14 (unused), 15 (unused)
*/ */
...@@ -1999,7 +2008,7 @@ static int lbs_leave_ibss(struct wiphy *wiphy, struct net_device *dev) ...@@ -1999,7 +2008,7 @@ static int lbs_leave_ibss(struct wiphy *wiphy, struct net_device *dev)
/*************************************************************************** /*
* Initialization * Initialization
*/ */
......
This diff is collapsed.
/** /*
* This file contains the handling of command * This file contains the handling of command
* responses as well as events generated by firmware. * responses as well as events generated by firmware.
*/ */
...@@ -12,12 +12,13 @@ ...@@ -12,12 +12,13 @@
#include "cmd.h" #include "cmd.h"
/** /**
* @brief This function handles disconnect event. it * lbs_mac_event_disconnected - handles disconnect event. It
* reports disconnect to upper layer, clean tx/rx packets, * reports disconnect to upper layer, clean tx/rx packets,
* reset link state etc. * reset link state etc.
* *
* @param priv A pointer to struct lbs_private structure * @priv: A pointer to struct lbs_private structure
* @return n/a *
* returns: n/a
*/ */
void lbs_mac_event_disconnected(struct lbs_private *priv) void lbs_mac_event_disconnected(struct lbs_private *priv)
{ {
......
...@@ -849,15 +849,14 @@ static struct debug_data items[] = { ...@@ -849,15 +849,14 @@ static struct debug_data items[] = {
static int num_of_items = ARRAY_SIZE(items); static int num_of_items = ARRAY_SIZE(items);
/** /**
* @brief proc read function * lbs_debugfs_read - proc read function
* *
* @param page pointer to buffer * @file: file to read
* @param s read data starting position * @userbuf: pointer to buffer
* @param off offset * @count: number of bytes to read
* @param cnt counter * @ppos: read data starting position
* @param eof end of file flag *
* @param data data to output * returns: amount of data read or negative error code
* @return number of output data
*/ */
static ssize_t lbs_debugfs_read(struct file *file, char __user *userbuf, static ssize_t lbs_debugfs_read(struct file *file, char __user *userbuf,
size_t count, loff_t *ppos) size_t count, loff_t *ppos)
...@@ -897,13 +896,14 @@ static ssize_t lbs_debugfs_read(struct file *file, char __user *userbuf, ...@@ -897,13 +896,14 @@ static ssize_t lbs_debugfs_read(struct file *file, char __user *userbuf,
} }
/** /**
* @brief proc write function * lbs_debugfs_write - proc write function
*
* @f: file pointer
* @buf: pointer to data buffer
* @cnt: data number to write
* @ppos: file position
* *
* @param f file pointer * returns: amount of data written
* @param buf pointer to data buffer
* @param cnt data number to write
* @param data data to write
* @return number of data
*/ */
static ssize_t lbs_debugfs_write(struct file *f, const char __user *buf, static ssize_t lbs_debugfs_write(struct file *f, const char __user *buf,
size_t cnt, loff_t *ppos) size_t cnt, loff_t *ppos)
...@@ -966,11 +966,11 @@ static const struct file_operations lbs_debug_fops = { ...@@ -966,11 +966,11 @@ static const struct file_operations lbs_debug_fops = {
}; };
/** /**
* @brief create debug proc file * lbs_debug_init - create debug proc file
*
* @priv: pointer to &struct lbs_private
* *
* @param priv pointer struct lbs_private * returns: N/A
* @param dev pointer net_device
* @return N/A
*/ */
static void lbs_debug_init(struct lbs_private *priv) static void lbs_debug_init(struct lbs_private *priv)
{ {
......
/** /*
* This file contains declaration referring to * This file contains declaration referring to
* functions defined in other source files * functions defined in other source files
*/ */
......
/** /*
* This header file contains global constant/enum definitions, * This header file contains global constant/enum definitions,
* global variable declaration. * global variable declaration.
*/ */
...@@ -123,19 +123,19 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in ...@@ -123,19 +123,19 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in
/** Buffer Constants */ /* Buffer Constants */
/* The size of SQ memory PPA, DPA are 8 DWORDs, that keep the physical /* The size of SQ memory PPA, DPA are 8 DWORDs, that keep the physical
* addresses of TxPD buffers. Station has only 8 TxPD available, Whereas * addresses of TxPD buffers. Station has only 8 TxPD available, Whereas
* driver has more local TxPDs. Each TxPD on the host memory is associated * driver has more local TxPDs. Each TxPD on the host memory is associated
* with a Tx control node. The driver maintains 8 RxPD descriptors for * with a Tx control node. The driver maintains 8 RxPD descriptors for
* station firmware to store Rx packet information. * station firmware to store Rx packet information.
* *
* Current version of MAC has a 32x6 multicast address buffer. * Current version of MAC has a 32x6 multicast address buffer.
* *
* 802.11b can have up to 14 channels, the driver keeps the * 802.11b can have up to 14 channels, the driver keeps the
* BSSID(MAC address) of each APs or Ad hoc stations it has sensed. * BSSID(MAC address) of each APs or Ad hoc stations it has sensed.
*/ */
#define MRVDRV_MAX_MULTICAST_LIST_SIZE 32 #define MRVDRV_MAX_MULTICAST_LIST_SIZE 32
#define LBS_NUM_CMD_BUFFERS 10 #define LBS_NUM_CMD_BUFFERS 10
...@@ -166,7 +166,7 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in ...@@ -166,7 +166,7 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in
#define WOL_RESULT_NOSPC_ERR 1 #define WOL_RESULT_NOSPC_ERR 1
#define WOL_RESULT_EEXIST_ERR 2 #define WOL_RESULT_EEXIST_ERR 2
/** Misc constants */ /* Misc constants */
/* This section defines 802.11 specific contants */ /* This section defines 802.11 specific contants */
#define MRVDRV_MAX_BSS_DESCRIPTS 16 #define MRVDRV_MAX_BSS_DESCRIPTS 16
...@@ -183,7 +183,8 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in ...@@ -183,7 +183,8 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in
#define MARVELL_MESH_IE_LENGTH 9 #define MARVELL_MESH_IE_LENGTH 9
/* Values used to populate the struct mrvl_mesh_ie. The only time you need this /*
* Values used to populate the struct mrvl_mesh_ie. The only time you need this
* is when enabling the mesh using CMD_MESH_CONFIG. * is when enabling the mesh using CMD_MESH_CONFIG.
*/ */
#define MARVELL_MESH_IE_TYPE 4 #define MARVELL_MESH_IE_TYPE 4
...@@ -193,7 +194,7 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in ...@@ -193,7 +194,7 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in
#define MARVELL_MESH_METRIC_ID 0 #define MARVELL_MESH_METRIC_ID 0
#define MARVELL_MESH_CAPABILITY 0 #define MARVELL_MESH_CAPABILITY 0
/** INT status Bit Definition*/ /* INT status Bit Definition */
#define MRVDRV_TX_DNLD_RDY 0x0001 #define MRVDRV_TX_DNLD_RDY 0x0001
#define MRVDRV_RX_UPLD_RDY 0x0002 #define MRVDRV_RX_UPLD_RDY 0x0002
#define MRVDRV_CMD_DNLD_RDY 0x0004 #define MRVDRV_CMD_DNLD_RDY 0x0004
...@@ -208,59 +209,63 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in ...@@ -208,59 +209,63 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in
#define TPC_DEFAULT_P1 10 #define TPC_DEFAULT_P1 10
#define TPC_DEFAULT_P2 13 #define TPC_DEFAULT_P2 13
/** TxPD status */ /* TxPD status */
/* Station firmware use TxPD status field to report final Tx transmit /*
* result, Bit masks are used to present combined situations. * Station firmware use TxPD status field to report final Tx transmit
*/ * result, Bit masks are used to present combined situations.
*/
#define MRVDRV_TxPD_POWER_MGMT_NULL_PACKET 0x01 #define MRVDRV_TxPD_POWER_MGMT_NULL_PACKET 0x01
#define MRVDRV_TxPD_POWER_MGMT_LAST_PACKET 0x08 #define MRVDRV_TxPD_POWER_MGMT_LAST_PACKET 0x08
/** Tx mesh flag */ /* Tx mesh flag */
/* Currently we are using normal WDS flag as mesh flag. /*
* Currently we are using normal WDS flag as mesh flag.
* TODO: change to proper mesh flag when MAC understands it. * TODO: change to proper mesh flag when MAC understands it.
*/ */
#define TxPD_CONTROL_WDS_FRAME (1<<17) #define TxPD_CONTROL_WDS_FRAME (1<<17)
#define TxPD_MESH_FRAME TxPD_CONTROL_WDS_FRAME #define TxPD_MESH_FRAME TxPD_CONTROL_WDS_FRAME
/** Mesh interface ID */ /* Mesh interface ID */
#define MESH_IFACE_ID 0x0001 #define MESH_IFACE_ID 0x0001
/** Mesh id should be in bits 14-13-12 */ /* Mesh id should be in bits 14-13-12 */
#define MESH_IFACE_BIT_OFFSET 0x000c #define MESH_IFACE_BIT_OFFSET 0x000c
/** Mesh enable bit in FW capability */ /* Mesh enable bit in FW capability */
#define MESH_CAPINFO_ENABLE_MASK (1<<16) #define MESH_CAPINFO_ENABLE_MASK (1<<16)
/** FW definition from Marvell v4 */ /* FW definition from Marvell v4 */
#define MRVL_FW_V4 (0x04) #define MRVL_FW_V4 (0x04)
/** FW definition from Marvell v5 */ /* FW definition from Marvell v5 */
#define MRVL_FW_V5 (0x05) #define MRVL_FW_V5 (0x05)
/** FW definition from Marvell v10 */ /* FW definition from Marvell v10 */
#define MRVL_FW_V10 (0x0a) #define MRVL_FW_V10 (0x0a)
/** FW major revision definition */ /* FW major revision definition */
#define MRVL_FW_MAJOR_REV(x) ((x)>>24) #define MRVL_FW_MAJOR_REV(x) ((x)>>24)
/** RxPD status */ /* RxPD status */
#define MRVDRV_RXPD_STATUS_OK 0x0001 #define MRVDRV_RXPD_STATUS_OK 0x0001
/** RxPD status - Received packet types */ /* RxPD status - Received packet types */
/** Rx mesh flag */ /* Rx mesh flag */
/* Currently we are using normal WDS flag as mesh flag. /*
* Currently we are using normal WDS flag as mesh flag.
* TODO: change to proper mesh flag when MAC understands it. * TODO: change to proper mesh flag when MAC understands it.
*/ */
#define RxPD_CONTROL_WDS_FRAME (0x40) #define RxPD_CONTROL_WDS_FRAME (0x40)
#define RxPD_MESH_FRAME RxPD_CONTROL_WDS_FRAME #define RxPD_MESH_FRAME RxPD_CONTROL_WDS_FRAME
/** RSSI-related defines */ /* RSSI-related defines */
/* RSSI constants are used to implement 802.11 RSSI threshold /*
* indication. if the Rx packet signal got too weak for 5 consecutive * RSSI constants are used to implement 802.11 RSSI threshold
* times, miniport driver (driver) will report this event to wrapper * indication. if the Rx packet signal got too weak for 5 consecutive
*/ * times, miniport driver (driver) will report this event to wrapper
*/
#define MRVDRV_NF_DEFAULT_SCAN_VALUE (-96) #define MRVDRV_NF_DEFAULT_SCAN_VALUE (-96)
/** RTS/FRAG related defines */ /* RTS/FRAG related defines */
#define MRVDRV_RTS_MIN_VALUE 0 #define MRVDRV_RTS_MIN_VALUE 0
#define MRVDRV_RTS_MAX_VALUE 2347 #define MRVDRV_RTS_MAX_VALUE 2347
#define MRVDRV_FRAG_MIN_VALUE 256 #define MRVDRV_FRAG_MIN_VALUE 256
...@@ -300,36 +305,36 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in ...@@ -300,36 +305,36 @@ static inline void lbs_deb_hex(unsigned int grp, const char *prompt, u8 *buf, in
#define MAX_LEDS 8 #define MAX_LEDS 8
/** Global Variable Declaration */ /* Global Variable Declaration */
extern const char lbs_driver_version[]; extern const char lbs_driver_version[];
extern u16 lbs_region_code_to_index[MRVDRV_MAX_REGION_CODE]; extern u16 lbs_region_code_to_index[MRVDRV_MAX_REGION_CODE];
/** ENUM definition*/ /* ENUM definition */
/** SNRNF_TYPE */ /* SNRNF_TYPE */
enum SNRNF_TYPE { enum SNRNF_TYPE {
TYPE_BEACON = 0, TYPE_BEACON = 0,
TYPE_RXPD, TYPE_RXPD,
MAX_TYPE_B MAX_TYPE_B
}; };
/** SNRNF_DATA*/ /* SNRNF_DATA */
enum SNRNF_DATA { enum SNRNF_DATA {
TYPE_NOAVG = 0, TYPE_NOAVG = 0,
TYPE_AVG, TYPE_AVG,
MAX_TYPE_AVG MAX_TYPE_AVG
}; };
/** LBS_802_11_POWER_MODE */ /* LBS_802_11_POWER_MODE */
enum LBS_802_11_POWER_MODE { enum LBS_802_11_POWER_MODE {
LBS802_11POWERMODECAM, LBS802_11POWERMODECAM,
LBS802_11POWERMODEMAX_PSP, LBS802_11POWERMODEMAX_PSP,
LBS802_11POWERMODEFAST_PSP, LBS802_11POWERMODEFAST_PSP,
/*not a real mode, defined as an upper bound */ /* not a real mode, defined as an upper bound */
LBS802_11POWEMODEMAX LBS802_11POWEMODEMAX
}; };
/** PS_STATE */ /* PS_STATE */
enum PS_STATE { enum PS_STATE {
PS_STATE_FULL_POWER, PS_STATE_FULL_POWER,
PS_STATE_AWAKE, PS_STATE_AWAKE,
...@@ -337,7 +342,7 @@ enum PS_STATE { ...@@ -337,7 +342,7 @@ enum PS_STATE {
PS_STATE_SLEEP PS_STATE_SLEEP
}; };
/** DNLD_STATE */ /* DNLD_STATE */
enum DNLD_STATE { enum DNLD_STATE {
DNLD_RES_RECEIVED, DNLD_RES_RECEIVED,
DNLD_DATA_SENT, DNLD_DATA_SENT,
...@@ -345,19 +350,19 @@ enum DNLD_STATE { ...@@ -345,19 +350,19 @@ enum DNLD_STATE {
DNLD_BOOTCMD_SENT, DNLD_BOOTCMD_SENT,
}; };
/** LBS_MEDIA_STATE */ /* LBS_MEDIA_STATE */
enum LBS_MEDIA_STATE { enum LBS_MEDIA_STATE {
LBS_CONNECTED, LBS_CONNECTED,
LBS_DISCONNECTED LBS_DISCONNECTED
}; };
/** LBS_802_11_PRIVACY_FILTER */ /* LBS_802_11_PRIVACY_FILTER */
enum LBS_802_11_PRIVACY_FILTER { enum LBS_802_11_PRIVACY_FILTER {
LBS802_11PRIVFILTERACCEPTALL, LBS802_11PRIVFILTERACCEPTALL,
LBS802_11PRIVFILTER8021XWEP LBS802_11PRIVFILTER8021XWEP
}; };
/** mv_ms_type */ /* mv_ms_type */
enum mv_ms_type { enum mv_ms_type {
MVMS_DAT = 0, MVMS_DAT = 0,
MVMS_CMD = 1, MVMS_CMD = 1,
...@@ -365,14 +370,14 @@ enum mv_ms_type { ...@@ -365,14 +370,14 @@ enum mv_ms_type {
MVMS_EVENT MVMS_EVENT
}; };
/** KEY_TYPE_ID */ /* KEY_TYPE_ID */
enum KEY_TYPE_ID { enum KEY_TYPE_ID {
KEY_TYPE_ID_WEP = 0, KEY_TYPE_ID_WEP = 0,
KEY_TYPE_ID_TKIP, KEY_TYPE_ID_TKIP,
KEY_TYPE_ID_AES KEY_TYPE_ID_AES
}; };
/** KEY_INFO_WPA (applies to both TKIP and AES/CCMP) */ /* KEY_INFO_WPA (applies to both TKIP and AES/CCMP) */
enum KEY_INFO_WPA { enum KEY_INFO_WPA {
KEY_INFO_WPA_MCAST = 0x01, KEY_INFO_WPA_MCAST = 0x01,
KEY_INFO_WPA_UNICAST = 0x02, KEY_INFO_WPA_UNICAST = 0x02,
......
/** /*
* This file contains definitions and data structures specific * This file contains definitions and data structures specific
* to Marvell 802.11 NIC. It contains the Device Information * to Marvell 802.11 NIC. It contains the Device Information
* structure struct lbs_private.. * structure struct lbs_private..
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
#include <linux/kfifo.h> #include <linux/kfifo.h>
/** sleep_params */ /* sleep_params */
struct sleep_params { struct sleep_params {
uint16_t sp_error; uint16_t sp_error;
uint16_t sp_offset; uint16_t sp_offset;
...@@ -23,7 +23,7 @@ struct sleep_params { ...@@ -23,7 +23,7 @@ struct sleep_params {
}; };
/** Private structure for the MV device */ /* Private structure for the MV device */
struct lbs_private { struct lbs_private {
/* Basic networking */ /* Basic networking */
...@@ -125,12 +125,12 @@ struct lbs_private { ...@@ -125,12 +125,12 @@ struct lbs_private {
/* Events sent from hardware to driver */ /* Events sent from hardware to driver */
struct kfifo event_fifo; struct kfifo event_fifo;
/** thread to service interrupts */ /* thread to service interrupts */
struct task_struct *main_thread; struct task_struct *main_thread;
wait_queue_head_t waitq; wait_queue_head_t waitq;
struct workqueue_struct *work_thread; struct workqueue_struct *work_thread;
/** Encryption stuff */ /* Encryption stuff */
u8 authtype_auto; u8 authtype_auto;
u8 wep_tx_key; u8 wep_tx_key;
u8 wep_key[4][WLAN_KEY_LEN_WEP104]; u8 wep_key[4][WLAN_KEY_LEN_WEP104];
...@@ -162,7 +162,7 @@ struct lbs_private { ...@@ -162,7 +162,7 @@ struct lbs_private {
s16 txpower_min; s16 txpower_min;
s16 txpower_max; s16 txpower_max;
/** Scanning */ /* Scanning */
struct delayed_work scan_work; struct delayed_work scan_work;
int scan_channel; int scan_channel;
/* Queue of things waiting for scan completion */ /* Queue of things waiting for scan completion */
......
...@@ -20,7 +20,8 @@ static void lbs_ethtool_get_drvinfo(struct net_device *dev, ...@@ -20,7 +20,8 @@ static void lbs_ethtool_get_drvinfo(struct net_device *dev,
strcpy(info->version, lbs_driver_version); strcpy(info->version, lbs_driver_version);
} }
/* All 8388 parts have 16KiB EEPROM size at the time of writing. /*
* All 8388 parts have 16KiB EEPROM size at the time of writing.
* In case that changes this needs fixing. * In case that changes this needs fixing.
*/ */
#define LBS_EEPROM_LEN 16384 #define LBS_EEPROM_LEN 16384
......
/** /*
* This file function prototypes, data structure * This file function prototypes, data structure
* and definitions for all the host/station commands * and definitions for all the host/station commands
*/ */
...@@ -13,9 +13,10 @@ ...@@ -13,9 +13,10 @@
#define CMD_OPTION_WAITFORRSP 0x0002 #define CMD_OPTION_WAITFORRSP 0x0002
/** Host command IDs */ /* Host command IDs */
/* Return command are almost always the same as the host command, but with /*
* Return command are almost always the same as the host command, but with
* bit 15 set high. There are a few exceptions, though... * bit 15 set high. There are a few exceptions, though...
*/ */
#define CMD_RET(cmd) (0x8000 | cmd) #define CMD_RET(cmd) (0x8000 | cmd)
...@@ -251,7 +252,7 @@ enum cmd_mesh_config_types { ...@@ -251,7 +252,7 @@ enum cmd_mesh_config_types {
CMD_TYPE_MESH_GET_MESH_IE, /* GET_DEFAULTS is superset of GET_MESHIE */ CMD_TYPE_MESH_GET_MESH_IE, /* GET_DEFAULTS is superset of GET_MESHIE */
}; };
/** Card Event definition */ /* Card Event definition */
#define MACREG_INT_CODE_TX_PPA_FREE 0 #define MACREG_INT_CODE_TX_PPA_FREE 0
#define MACREG_INT_CODE_TX_DMA_DONE 1 #define MACREG_INT_CODE_TX_DMA_DONE 1
#define MACREG_INT_CODE_LINK_LOST_W_SCAN 2 #define MACREG_INT_CODE_LINK_LOST_W_SCAN 2
...@@ -624,12 +625,14 @@ struct cmd_ds_802_11_rf_channel { ...@@ -624,12 +625,14 @@ struct cmd_ds_802_11_rf_channel {
struct cmd_ds_802_11_rssi { struct cmd_ds_802_11_rssi {
struct cmd_header hdr; struct cmd_header hdr;
/* request: number of beacons (N) to average the SNR and NF over /*
* request: number of beacons (N) to average the SNR and NF over
* response: SNR of most recent beacon * response: SNR of most recent beacon
*/ */
__le16 n_or_snr; __le16 n_or_snr;
/* The following fields are only set in the response. /*
* The following fields are only set in the response.
* In the request these are reserved and should be set to 0. * In the request these are reserved and should be set to 0.
*/ */
__le16 nf; /* most recent beacon noise floor */ __le16 nf; /* most recent beacon noise floor */
...@@ -680,14 +683,16 @@ struct cmd_ds_802_11_ps_mode { ...@@ -680,14 +683,16 @@ struct cmd_ds_802_11_ps_mode {
__le16 action; __le16 action;
/* Interval for keepalive in PS mode: /*
* Interval for keepalive in PS mode:
* 0x0000 = don't change * 0x0000 = don't change
* 0x001E = firmware default * 0x001E = firmware default
* 0xFFFF = disable * 0xFFFF = disable
*/ */
__le16 nullpktinterval; __le16 nullpktinterval;
/* Number of DTIM intervals to wake up for: /*
* Number of DTIM intervals to wake up for:
* 0 = don't change * 0 = don't change
* 1 = firmware default * 1 = firmware default
* 5 = max * 5 = max
...@@ -697,7 +702,8 @@ struct cmd_ds_802_11_ps_mode { ...@@ -697,7 +702,8 @@ struct cmd_ds_802_11_ps_mode {
__le16 reserved; __le16 reserved;
__le16 locallisteninterval; __le16 locallisteninterval;
/* AdHoc awake period (FW v9+ only): /*
* AdHoc awake period (FW v9+ only):
* 0 = don't change * 0 = don't change
* 1 = always awake (IEEE standard behavior) * 1 = always awake (IEEE standard behavior)
* 2 - 31 = sleep for (n - 1) periods and awake for 1 period * 2 - 31 = sleep for (n - 1) periods and awake for 1 period
...@@ -771,7 +777,8 @@ struct adhoc_bssdesc { ...@@ -771,7 +777,8 @@ struct adhoc_bssdesc {
__le16 capability; __le16 capability;
u8 rates[MAX_RATES]; u8 rates[MAX_RATES];
/* DO NOT ADD ANY FIELDS TO THIS STRUCTURE. It is used below in the /*
* DO NOT ADD ANY FIELDS TO THIS STRUCTURE. It is used below in the
* Adhoc join command and will cause a binary layout mismatch with * Adhoc join command and will cause a binary layout mismatch with
* the firmware * the firmware
*/ */
......
...@@ -312,7 +312,8 @@ static int if_cs_poll_while_fw_download(struct if_cs_card *card, uint addr, u8 r ...@@ -312,7 +312,8 @@ static int if_cs_poll_while_fw_download(struct if_cs_card *card, uint addr, u8 r
#define CF8385_MANFID 0x02df #define CF8385_MANFID 0x02df
#define CF8385_CARDID 0x8103 #define CF8385_CARDID 0x8103
/* FIXME: just use the 'driver_info' field of 'struct pcmcia_device_id' when /*
* FIXME: just use the 'driver_info' field of 'struct pcmcia_device_id' when
* that gets fixed. Currently there's no way to access it from the probe hook. * that gets fixed. Currently there's no way to access it from the probe hook.
*/ */
static inline u32 get_model(u16 manf_id, u16 card_id) static inline u32 get_model(u16 manf_id, u16 card_id)
...@@ -621,8 +622,10 @@ static int if_cs_prog_helper(struct if_cs_card *card, const struct firmware *fw) ...@@ -621,8 +622,10 @@ static int if_cs_prog_helper(struct if_cs_card *card, const struct firmware *fw)
if (remain < count) if (remain < count)
count = remain; count = remain;
/* "write the number of bytes to be sent to the I/O Command /*
* write length register" */ * "write the number of bytes to be sent to the I/O Command
* write length register"
*/
if_cs_write16(card, IF_CS_CMD_LEN, count); if_cs_write16(card, IF_CS_CMD_LEN, count);
/* "write this to I/O Command port register as 16 bit writes */ /* "write this to I/O Command port register as 16 bit writes */
...@@ -631,16 +634,22 @@ static int if_cs_prog_helper(struct if_cs_card *card, const struct firmware *fw) ...@@ -631,16 +634,22 @@ static int if_cs_prog_helper(struct if_cs_card *card, const struct firmware *fw)
&fw->data[sent], &fw->data[sent],
count >> 1); count >> 1);
/* "Assert the download over interrupt command in the Host /*
* status register" */ * "Assert the download over interrupt command in the Host
* status register"
*/
if_cs_write8(card, IF_CS_HOST_STATUS, IF_CS_BIT_COMMAND); if_cs_write8(card, IF_CS_HOST_STATUS, IF_CS_BIT_COMMAND);
/* "Assert the download over interrupt command in the Card /*
* interrupt case register" */ * "Assert the download over interrupt command in the Card
* interrupt case register"
*/
if_cs_write16(card, IF_CS_HOST_INT_CAUSE, IF_CS_BIT_COMMAND); if_cs_write16(card, IF_CS_HOST_INT_CAUSE, IF_CS_BIT_COMMAND);
/* "The host polls the Card Status register ... for 50 ms before /*
declaring a failure */ * "The host polls the Card Status register ... for 50 ms before
* declaring a failure"
*/
ret = if_cs_poll_while_fw_download(card, IF_CS_CARD_STATUS, ret = if_cs_poll_while_fw_download(card, IF_CS_CARD_STATUS,
IF_CS_BIT_COMMAND); IF_CS_BIT_COMMAND);
if (ret < 0) { if (ret < 0) {
...@@ -841,7 +850,7 @@ static int if_cs_probe(struct pcmcia_device *p_dev) ...@@ -841,7 +850,7 @@ static int if_cs_probe(struct pcmcia_device *p_dev)
/* /*
* Most of the libertas cards can do unaligned register access, but some * Most of the libertas cards can do unaligned register access, but some
* weird ones can not. That's especially true for the CF8305 card. * weird ones cannot. That's especially true for the CF8305 card.
*/ */
card->align_regs = 0; card->align_regs = 0;
...@@ -913,8 +922,10 @@ static int if_cs_probe(struct pcmcia_device *p_dev) ...@@ -913,8 +922,10 @@ static int if_cs_probe(struct pcmcia_device *p_dev)
goto out3; goto out3;
} }
/* Clear any interrupt cause that happend while sending /*
* firmware/initializing card */ * Clear any interrupt cause that happened while sending
* firmware/initializing card
*/
if_cs_write16(card, IF_CS_CARD_INT_CAUSE, IF_CS_BIT_MASK); if_cs_write16(card, IF_CS_CARD_INT_CAUSE, IF_CS_BIT_MASK);
if_cs_enable_ints(card); if_cs_enable_ints(card);
......
...@@ -143,8 +143,10 @@ static void spu_transaction_finish(struct if_spi_card *card) ...@@ -143,8 +143,10 @@ static void spu_transaction_finish(struct if_spi_card *card)
card->prev_xfer_time = jiffies; card->prev_xfer_time = jiffies;
} }
/* Write out a byte buffer to an SPI register, /*
* using a series of 16-bit transfers. */ * Write out a byte buffer to an SPI register,
* using a series of 16-bit transfers.
*/
static int spu_write(struct if_spi_card *card, u16 reg, const u8 *buf, int len) static int spu_write(struct if_spi_card *card, u16 reg, const u8 *buf, int len)
{ {
int err = 0; int err = 0;
...@@ -208,8 +210,10 @@ static int spu_read(struct if_spi_card *card, u16 reg, u8 *buf, int len) ...@@ -208,8 +210,10 @@ static int spu_read(struct if_spi_card *card, u16 reg, u8 *buf, int len)
struct spi_transfer dummy_trans; struct spi_transfer dummy_trans;
struct spi_transfer data_trans; struct spi_transfer data_trans;
/* You must take an even number of bytes from the SPU, even if you /*
* don't care about the last one. */ * You must take an even number of bytes from the SPU, even if you
* don't care about the last one.
*/
BUG_ON(len & 0x1); BUG_ON(len & 0x1);
spu_transaction_init(card); spu_transaction_init(card);
...@@ -258,8 +262,10 @@ static inline int spu_read_u16(struct if_spi_card *card, u16 reg, u16 *val) ...@@ -258,8 +262,10 @@ static inline int spu_read_u16(struct if_spi_card *card, u16 reg, u16 *val)
return ret; return ret;
} }
/* Read 32 bits from an SPI register. /*
* The low 16 bits are read first. */ * Read 32 bits from an SPI register.
* The low 16 bits are read first.
*/
static int spu_read_u32(struct if_spi_card *card, u16 reg, u32 *val) static int spu_read_u32(struct if_spi_card *card, u16 reg, u32 *val)
{ {
__le32 buf; __le32 buf;
...@@ -271,13 +277,15 @@ static int spu_read_u32(struct if_spi_card *card, u16 reg, u32 *val) ...@@ -271,13 +277,15 @@ static int spu_read_u32(struct if_spi_card *card, u16 reg, u32 *val)
return err; return err;
} }
/* Keep reading 16 bits from an SPI register until you get the correct result. /*
* Keep reading 16 bits from an SPI register until you get the correct result.
* *
* If mask = 0, the correct result is any non-zero number. * If mask = 0, the correct result is any non-zero number.
* If mask != 0, the correct result is any number where * If mask != 0, the correct result is any number where
* number & target_mask == target * number & target_mask == target
* *
* Returns -ETIMEDOUT if a second passes without the correct result. */ * Returns -ETIMEDOUT if a second passes without the correct result.
*/
static int spu_wait_for_u16(struct if_spi_card *card, u16 reg, static int spu_wait_for_u16(struct if_spi_card *card, u16 reg,
u16 target_mask, u16 target) u16 target_mask, u16 target)
{ {
...@@ -305,8 +313,10 @@ static int spu_wait_for_u16(struct if_spi_card *card, u16 reg, ...@@ -305,8 +313,10 @@ static int spu_wait_for_u16(struct if_spi_card *card, u16 reg,
} }
} }
/* Read 16 bits from an SPI register until you receive a specific value. /*
* Returns -ETIMEDOUT if a 4 tries pass without success. */ * Read 16 bits from an SPI register until you receive a specific value.
* Returns -ETIMEDOUT if a 4 tries pass without success.
*/
static int spu_wait_for_u32(struct if_spi_card *card, u32 reg, u32 target) static int spu_wait_for_u32(struct if_spi_card *card, u32 reg, u32 target)
{ {
int err, try; int err, try;
...@@ -328,8 +338,10 @@ static int spu_set_interrupt_mode(struct if_spi_card *card, ...@@ -328,8 +338,10 @@ static int spu_set_interrupt_mode(struct if_spi_card *card,
{ {
int err = 0; int err = 0;
/* We can suppress a host interrupt by clearing the appropriate /*
* bit in the "host interrupt status mask" register */ * We can suppress a host interrupt by clearing the appropriate
* bit in the "host interrupt status mask" register
*/
if (suppress_host_int) { if (suppress_host_int) {
err = spu_write_u16(card, IF_SPI_HOST_INT_STATUS_MASK_REG, 0); err = spu_write_u16(card, IF_SPI_HOST_INT_STATUS_MASK_REG, 0);
if (err) if (err)
...@@ -345,10 +357,12 @@ static int spu_set_interrupt_mode(struct if_spi_card *card, ...@@ -345,10 +357,12 @@ static int spu_set_interrupt_mode(struct if_spi_card *card,
return err; return err;
} }
/* If auto-interrupts are on, the completion of certain transactions /*
* If auto-interrupts are on, the completion of certain transactions
* will trigger an interrupt automatically. If auto-interrupts * will trigger an interrupt automatically. If auto-interrupts
* are off, we need to set the "Card Interrupt Cause" register to * are off, we need to set the "Card Interrupt Cause" register to
* trigger a card interrupt. */ * trigger a card interrupt.
*/
if (auto_int) { if (auto_int) {
err = spu_write_u16(card, IF_SPI_HOST_INT_CTRL_REG, err = spu_write_u16(card, IF_SPI_HOST_INT_CTRL_REG,
IF_SPI_HICT_TX_DOWNLOAD_OVER_AUTO | IF_SPI_HICT_TX_DOWNLOAD_OVER_AUTO |
...@@ -402,8 +416,10 @@ static int spu_init(struct if_spi_card *card, int use_dummy_writes) ...@@ -402,8 +416,10 @@ static int spu_init(struct if_spi_card *card, int use_dummy_writes)
int err = 0; int err = 0;
u32 delay; u32 delay;
/* We have to start up in timed delay mode so that we can safely /*
* read the Delay Read Register. */ * We have to start up in timed delay mode so that we can safely
* read the Delay Read Register.
*/
card->use_dummy_writes = 0; card->use_dummy_writes = 0;
err = spu_set_bus_mode(card, err = spu_set_bus_mode(card,
IF_SPI_BUS_MODE_SPI_CLOCK_PHASE_RISING | IF_SPI_BUS_MODE_SPI_CLOCK_PHASE_RISING |
...@@ -459,8 +475,10 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card, ...@@ -459,8 +475,10 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card,
/* Load helper firmware image */ /* Load helper firmware image */
while (bytes_remaining > 0) { while (bytes_remaining > 0) {
/* Scratch pad 1 should contain the number of bytes we /*
* want to download to the firmware */ * Scratch pad 1 should contain the number of bytes we
* want to download to the firmware
*/
err = spu_write_u16(card, IF_SPI_SCRATCH_1_REG, err = spu_write_u16(card, IF_SPI_SCRATCH_1_REG,
HELPER_FW_LOAD_CHUNK_SZ); HELPER_FW_LOAD_CHUNK_SZ);
if (err) if (err)
...@@ -472,8 +490,10 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card, ...@@ -472,8 +490,10 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card,
if (err) if (err)
goto out; goto out;
/* Feed the data into the command read/write port reg /*
* in chunks of 64 bytes */ * Feed the data into the command read/write port reg
* in chunks of 64 bytes
*/
memset(temp, 0, sizeof(temp)); memset(temp, 0, sizeof(temp));
memcpy(temp, fw, memcpy(temp, fw,
min(bytes_remaining, HELPER_FW_LOAD_CHUNK_SZ)); min(bytes_remaining, HELPER_FW_LOAD_CHUNK_SZ));
...@@ -495,9 +515,11 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card, ...@@ -495,9 +515,11 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card,
fw += HELPER_FW_LOAD_CHUNK_SZ; fw += HELPER_FW_LOAD_CHUNK_SZ;
} }
/* Once the helper / single stage firmware download is complete, /*
* Once the helper / single stage firmware download is complete,
* write 0 to scratch pad 1 and interrupt the * write 0 to scratch pad 1 and interrupt the
* bootloader. This completes the helper download. */ * bootloader. This completes the helper download.
*/
err = spu_write_u16(card, IF_SPI_SCRATCH_1_REG, FIRMWARE_DNLD_OK); err = spu_write_u16(card, IF_SPI_SCRATCH_1_REG, FIRMWARE_DNLD_OK);
if (err) if (err)
goto out; goto out;
...@@ -517,16 +539,20 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card, ...@@ -517,16 +539,20 @@ static int if_spi_prog_helper_firmware(struct if_spi_card *card,
return err; return err;
} }
/* Returns the length of the next packet the firmware expects us to send /*
* Sets crc_err if the previous transfer had a CRC error. */ * Returns the length of the next packet the firmware expects us to send.
* Sets crc_err if the previous transfer had a CRC error.
*/
static int if_spi_prog_main_firmware_check_len(struct if_spi_card *card, static int if_spi_prog_main_firmware_check_len(struct if_spi_card *card,
int *crc_err) int *crc_err)
{ {
u16 len; u16 len;
int err = 0; int err = 0;
/* wait until the host interrupt status register indicates /*
* that we are ready to download */ * wait until the host interrupt status register indicates
* that we are ready to download
*/
err = spu_wait_for_u16(card, IF_SPI_HOST_INT_STATUS_REG, err = spu_wait_for_u16(card, IF_SPI_HOST_INT_STATUS_REG,
IF_SPI_HIST_CMD_DOWNLOAD_RDY, IF_SPI_HIST_CMD_DOWNLOAD_RDY,
IF_SPI_HIST_CMD_DOWNLOAD_RDY); IF_SPI_HIST_CMD_DOWNLOAD_RDY);
...@@ -587,8 +613,10 @@ static int if_spi_prog_main_firmware(struct if_spi_card *card, ...@@ -587,8 +613,10 @@ static int if_spi_prog_main_firmware(struct if_spi_card *card,
goto out; goto out;
} }
if (bytes < 0) { if (bytes < 0) {
/* If there are no more bytes left, we would normally /*
* expect to have terminated with len = 0 */ * If there are no more bytes left, we would normally
* expect to have terminated with len = 0
*/
lbs_pr_err("Firmware load wants more bytes " lbs_pr_err("Firmware load wants more bytes "
"than we have to offer.\n"); "than we have to offer.\n");
break; break;
...@@ -660,14 +688,18 @@ static int if_spi_c2h_cmd(struct if_spi_card *card) ...@@ -660,14 +688,18 @@ static int if_spi_c2h_cmd(struct if_spi_card *card)
u16 len; u16 len;
u8 i; u8 i;
/* We need a buffer big enough to handle whatever people send to /*
* hw_host_to_card */ * We need a buffer big enough to handle whatever people send to
* hw_host_to_card
*/
BUILD_BUG_ON(IF_SPI_CMD_BUF_SIZE < LBS_CMD_BUFFER_SIZE); BUILD_BUG_ON(IF_SPI_CMD_BUF_SIZE < LBS_CMD_BUFFER_SIZE);
BUILD_BUG_ON(IF_SPI_CMD_BUF_SIZE < LBS_UPLD_SIZE); BUILD_BUG_ON(IF_SPI_CMD_BUF_SIZE < LBS_UPLD_SIZE);
/* It's just annoying if the buffer size isn't a multiple of 4, because /*
* It's just annoying if the buffer size isn't a multiple of 4, because
* then we might have len < IF_SPI_CMD_BUF_SIZE but * then we might have len < IF_SPI_CMD_BUF_SIZE but
* ALIGN(len, 4) > IF_SPI_CMD_BUF_SIZE */ * ALIGN(len, 4) > IF_SPI_CMD_BUF_SIZE
*/
BUILD_BUG_ON(IF_SPI_CMD_BUF_SIZE % 4 != 0); BUILD_BUG_ON(IF_SPI_CMD_BUF_SIZE % 4 != 0);
lbs_deb_enter(LBS_DEB_SPI); lbs_deb_enter(LBS_DEB_SPI);
...@@ -838,8 +870,10 @@ static void if_spi_host_to_card_worker(struct work_struct *work) ...@@ -838,8 +870,10 @@ static void if_spi_host_to_card_worker(struct work_struct *work)
lbs_deb_enter(LBS_DEB_SPI); lbs_deb_enter(LBS_DEB_SPI);
/* Read the host interrupt status register to see what we /*
* can do. */ * Read the host interrupt status register to see what we
* can do.
*/
err = spu_read_u16(card, IF_SPI_HOST_INT_STATUS_REG, err = spu_read_u16(card, IF_SPI_HOST_INT_STATUS_REG,
&hiStatus); &hiStatus);
if (err) { if (err) {
...@@ -858,12 +892,15 @@ static void if_spi_host_to_card_worker(struct work_struct *work) ...@@ -858,12 +892,15 @@ static void if_spi_host_to_card_worker(struct work_struct *work)
goto err; goto err;
} }
/* workaround: in PS mode, the card does not set the Command /*
* Download Ready bit, but it sets TX Download Ready. */ * workaround: in PS mode, the card does not set the Command
* Download Ready bit, but it sets TX Download Ready.
*/
if (hiStatus & IF_SPI_HIST_CMD_DOWNLOAD_RDY || if (hiStatus & IF_SPI_HIST_CMD_DOWNLOAD_RDY ||
(card->priv->psstate != PS_STATE_FULL_POWER && (card->priv->psstate != PS_STATE_FULL_POWER &&
(hiStatus & IF_SPI_HIST_TX_DOWNLOAD_RDY))) { (hiStatus & IF_SPI_HIST_TX_DOWNLOAD_RDY))) {
/* This means two things. First of all, /*
* This means two things. First of all,
* if there was a previous command sent, the card has * if there was a previous command sent, the card has
* successfully received it. * successfully received it.
* Secondly, it is now ready to download another * Secondly, it is now ready to download another
...@@ -871,8 +908,7 @@ static void if_spi_host_to_card_worker(struct work_struct *work) ...@@ -871,8 +908,7 @@ static void if_spi_host_to_card_worker(struct work_struct *work)
*/ */
lbs_host_to_card_done(card->priv); lbs_host_to_card_done(card->priv);
/* Do we have any command packets from the host to /* Do we have any command packets from the host to send? */
* send? */
packet = NULL; packet = NULL;
spin_lock_irqsave(&card->buffer_lock, flags); spin_lock_irqsave(&card->buffer_lock, flags);
if (!list_empty(&card->cmd_packet_list)) { if (!list_empty(&card->cmd_packet_list)) {
...@@ -886,8 +922,7 @@ static void if_spi_host_to_card_worker(struct work_struct *work) ...@@ -886,8 +922,7 @@ static void if_spi_host_to_card_worker(struct work_struct *work)
if_spi_h2c(card, packet, MVMS_CMD); if_spi_h2c(card, packet, MVMS_CMD);
} }
if (hiStatus & IF_SPI_HIST_TX_DOWNLOAD_RDY) { if (hiStatus & IF_SPI_HIST_TX_DOWNLOAD_RDY) {
/* Do we have any data packets from the host to /* Do we have any data packets from the host to send? */
* send? */
packet = NULL; packet = NULL;
spin_lock_irqsave(&card->buffer_lock, flags); spin_lock_irqsave(&card->buffer_lock, flags);
if (!list_empty(&card->data_packet_list)) { if (!list_empty(&card->data_packet_list)) {
...@@ -914,7 +949,8 @@ static void if_spi_host_to_card_worker(struct work_struct *work) ...@@ -914,7 +949,8 @@ static void if_spi_host_to_card_worker(struct work_struct *work)
* Host to Card * Host to Card
* *
* Called from Libertas to transfer some data to the WLAN device * Called from Libertas to transfer some data to the WLAN device
* We can't sleep here. */ * We can't sleep here.
*/
static int if_spi_host_to_card(struct lbs_private *priv, static int if_spi_host_to_card(struct lbs_private *priv,
u8 type, u8 *buf, u16 nb) u8 type, u8 *buf, u16 nb)
{ {
...@@ -1125,8 +1161,10 @@ static int __devinit if_spi_probe(struct spi_device *spi) ...@@ -1125,8 +1161,10 @@ static int __devinit if_spi_probe(struct spi_device *spi)
if (err) if (err)
goto free_card; goto free_card;
/* Register our card with libertas. /*
* This will call alloc_etherdev */ * Register our card with libertas.
* This will call alloc_etherdev.
*/
priv = lbs_add_card(card, &spi->dev); priv = lbs_add_card(card, &spi->dev);
if (!priv) { if (!priv) {
err = -ENOMEM; err = -ENOMEM;
...@@ -1153,9 +1191,11 @@ static int __devinit if_spi_probe(struct spi_device *spi) ...@@ -1153,9 +1191,11 @@ static int __devinit if_spi_probe(struct spi_device *spi)
goto terminate_workqueue; goto terminate_workqueue;
} }
/* Start the card. /*
* Start the card.
* This will call register_netdev, and we'll start * This will call register_netdev, and we'll start
* getting interrupts... */ * getting interrupts...
*/
err = lbs_start_card(priv); err = lbs_start_card(priv);
if (err) if (err)
goto release_irq; goto release_irq;
......
...@@ -86,34 +86,34 @@ ...@@ -86,34 +86,34 @@
#define IF_SPI_DEVICEID_CTRL_REG_TO_CARD_REV(dc) (dc & 0x000000ff) #define IF_SPI_DEVICEID_CTRL_REG_TO_CARD_REV(dc) (dc & 0x000000ff)
/***************** IF_SPI_HOST_INT_CTRL_REG *****************/ /***************** IF_SPI_HOST_INT_CTRL_REG *****************/
/** Host Interrupt Control bit : Wake up */ /* Host Interrupt Control bit : Wake up */
#define IF_SPI_HICT_WAKE_UP (1<<0) #define IF_SPI_HICT_WAKE_UP (1<<0)
/** Host Interrupt Control bit : WLAN ready */ /* Host Interrupt Control bit : WLAN ready */
#define IF_SPI_HICT_WLAN_READY (1<<1) #define IF_SPI_HICT_WLAN_READY (1<<1)
/*#define IF_SPI_HICT_FIFO_FIRST_HALF_EMPTY (1<<2) */ /*#define IF_SPI_HICT_FIFO_FIRST_HALF_EMPTY (1<<2) */
/*#define IF_SPI_HICT_FIFO_SECOND_HALF_EMPTY (1<<3) */ /*#define IF_SPI_HICT_FIFO_SECOND_HALF_EMPTY (1<<3) */
/*#define IF_SPI_HICT_IRQSRC_WLAN (1<<4) */ /*#define IF_SPI_HICT_IRQSRC_WLAN (1<<4) */
/** Host Interrupt Control bit : Tx auto download */ /* Host Interrupt Control bit : Tx auto download */
#define IF_SPI_HICT_TX_DOWNLOAD_OVER_AUTO (1<<5) #define IF_SPI_HICT_TX_DOWNLOAD_OVER_AUTO (1<<5)
/** Host Interrupt Control bit : Rx auto upload */ /* Host Interrupt Control bit : Rx auto upload */
#define IF_SPI_HICT_RX_UPLOAD_OVER_AUTO (1<<6) #define IF_SPI_HICT_RX_UPLOAD_OVER_AUTO (1<<6)
/** Host Interrupt Control bit : Command auto download */ /* Host Interrupt Control bit : Command auto download */
#define IF_SPI_HICT_CMD_DOWNLOAD_OVER_AUTO (1<<7) #define IF_SPI_HICT_CMD_DOWNLOAD_OVER_AUTO (1<<7)
/** Host Interrupt Control bit : Command auto upload */ /* Host Interrupt Control bit : Command auto upload */
#define IF_SPI_HICT_CMD_UPLOAD_OVER_AUTO (1<<8) #define IF_SPI_HICT_CMD_UPLOAD_OVER_AUTO (1<<8)
/***************** IF_SPI_CARD_INT_CAUSE_REG *****************/ /***************** IF_SPI_CARD_INT_CAUSE_REG *****************/
/** Card Interrupt Case bit : Tx download over */ /* Card Interrupt Case bit : Tx download over */
#define IF_SPI_CIC_TX_DOWNLOAD_OVER (1<<0) #define IF_SPI_CIC_TX_DOWNLOAD_OVER (1<<0)
/** Card Interrupt Case bit : Rx upload over */ /* Card Interrupt Case bit : Rx upload over */
#define IF_SPI_CIC_RX_UPLOAD_OVER (1<<1) #define IF_SPI_CIC_RX_UPLOAD_OVER (1<<1)
/** Card Interrupt Case bit : Command download over */ /* Card Interrupt Case bit : Command download over */
#define IF_SPI_CIC_CMD_DOWNLOAD_OVER (1<<2) #define IF_SPI_CIC_CMD_DOWNLOAD_OVER (1<<2)
/** Card Interrupt Case bit : Host event */ /* Card Interrupt Case bit : Host event */
#define IF_SPI_CIC_HOST_EVENT (1<<3) #define IF_SPI_CIC_HOST_EVENT (1<<3)
/** Card Interrupt Case bit : Command upload over */ /* Card Interrupt Case bit : Command upload over */
#define IF_SPI_CIC_CMD_UPLOAD_OVER (1<<4) #define IF_SPI_CIC_CMD_UPLOAD_OVER (1<<4)
/** Card Interrupt Case bit : Power down */ /* Card Interrupt Case bit : Power down */
#define IF_SPI_CIC_POWER_DOWN (1<<5) #define IF_SPI_CIC_POWER_DOWN (1<<5)
/***************** IF_SPI_CARD_INT_STATUS_REG *****************/ /***************** IF_SPI_CARD_INT_STATUS_REG *****************/
...@@ -138,51 +138,51 @@ ...@@ -138,51 +138,51 @@
#define IF_SPI_HICU_CMD_RD_FIFO_UNDERFLOW (1<<10) #define IF_SPI_HICU_CMD_RD_FIFO_UNDERFLOW (1<<10)
/***************** IF_SPI_HOST_INT_STATUS_REG *****************/ /***************** IF_SPI_HOST_INT_STATUS_REG *****************/
/** Host Interrupt Status bit : Tx download ready */ /* Host Interrupt Status bit : Tx download ready */
#define IF_SPI_HIST_TX_DOWNLOAD_RDY (1<<0) #define IF_SPI_HIST_TX_DOWNLOAD_RDY (1<<0)
/** Host Interrupt Status bit : Rx upload ready */ /* Host Interrupt Status bit : Rx upload ready */
#define IF_SPI_HIST_RX_UPLOAD_RDY (1<<1) #define IF_SPI_HIST_RX_UPLOAD_RDY (1<<1)
/** Host Interrupt Status bit : Command download ready */ /* Host Interrupt Status bit : Command download ready */
#define IF_SPI_HIST_CMD_DOWNLOAD_RDY (1<<2) #define IF_SPI_HIST_CMD_DOWNLOAD_RDY (1<<2)
/** Host Interrupt Status bit : Card event */ /* Host Interrupt Status bit : Card event */
#define IF_SPI_HIST_CARD_EVENT (1<<3) #define IF_SPI_HIST_CARD_EVENT (1<<3)
/** Host Interrupt Status bit : Command upload ready */ /* Host Interrupt Status bit : Command upload ready */
#define IF_SPI_HIST_CMD_UPLOAD_RDY (1<<4) #define IF_SPI_HIST_CMD_UPLOAD_RDY (1<<4)
/** Host Interrupt Status bit : I/O write FIFO overflow */ /* Host Interrupt Status bit : I/O write FIFO overflow */
#define IF_SPI_HIST_IO_WR_FIFO_OVERFLOW (1<<5) #define IF_SPI_HIST_IO_WR_FIFO_OVERFLOW (1<<5)
/** Host Interrupt Status bit : I/O read FIFO underflow */ /* Host Interrupt Status bit : I/O read FIFO underflow */
#define IF_SPI_HIST_IO_RD_FIFO_UNDRFLOW (1<<6) #define IF_SPI_HIST_IO_RD_FIFO_UNDRFLOW (1<<6)
/** Host Interrupt Status bit : Data write FIFO overflow */ /* Host Interrupt Status bit : Data write FIFO overflow */
#define IF_SPI_HIST_DATA_WR_FIFO_OVERFLOW (1<<7) #define IF_SPI_HIST_DATA_WR_FIFO_OVERFLOW (1<<7)
/** Host Interrupt Status bit : Data read FIFO underflow */ /* Host Interrupt Status bit : Data read FIFO underflow */
#define IF_SPI_HIST_DATA_RD_FIFO_UNDERFLOW (1<<8) #define IF_SPI_HIST_DATA_RD_FIFO_UNDERFLOW (1<<8)
/** Host Interrupt Status bit : Command write FIFO overflow */ /* Host Interrupt Status bit : Command write FIFO overflow */
#define IF_SPI_HIST_CMD_WR_FIFO_OVERFLOW (1<<9) #define IF_SPI_HIST_CMD_WR_FIFO_OVERFLOW (1<<9)
/** Host Interrupt Status bit : Command read FIFO underflow */ /* Host Interrupt Status bit : Command read FIFO underflow */
#define IF_SPI_HIST_CMD_RD_FIFO_UNDERFLOW (1<<10) #define IF_SPI_HIST_CMD_RD_FIFO_UNDERFLOW (1<<10)
/***************** IF_SPI_HOST_INT_STATUS_MASK_REG *****************/ /***************** IF_SPI_HOST_INT_STATUS_MASK_REG *****************/
/** Host Interrupt Status Mask bit : Tx download ready */ /* Host Interrupt Status Mask bit : Tx download ready */
#define IF_SPI_HISM_TX_DOWNLOAD_RDY (1<<0) #define IF_SPI_HISM_TX_DOWNLOAD_RDY (1<<0)
/** Host Interrupt Status Mask bit : Rx upload ready */ /* Host Interrupt Status Mask bit : Rx upload ready */
#define IF_SPI_HISM_RX_UPLOAD_RDY (1<<1) #define IF_SPI_HISM_RX_UPLOAD_RDY (1<<1)
/** Host Interrupt Status Mask bit : Command download ready */ /* Host Interrupt Status Mask bit : Command download ready */
#define IF_SPI_HISM_CMD_DOWNLOAD_RDY (1<<2) #define IF_SPI_HISM_CMD_DOWNLOAD_RDY (1<<2)
/** Host Interrupt Status Mask bit : Card event */ /* Host Interrupt Status Mask bit : Card event */
#define IF_SPI_HISM_CARDEVENT (1<<3) #define IF_SPI_HISM_CARDEVENT (1<<3)
/** Host Interrupt Status Mask bit : Command upload ready */ /* Host Interrupt Status Mask bit : Command upload ready */
#define IF_SPI_HISM_CMD_UPLOAD_RDY (1<<4) #define IF_SPI_HISM_CMD_UPLOAD_RDY (1<<4)
/** Host Interrupt Status Mask bit : I/O write FIFO overflow */ /* Host Interrupt Status Mask bit : I/O write FIFO overflow */
#define IF_SPI_HISM_IO_WR_FIFO_OVERFLOW (1<<5) #define IF_SPI_HISM_IO_WR_FIFO_OVERFLOW (1<<5)
/** Host Interrupt Status Mask bit : I/O read FIFO underflow */ /* Host Interrupt Status Mask bit : I/O read FIFO underflow */
#define IF_SPI_HISM_IO_RD_FIFO_UNDERFLOW (1<<6) #define IF_SPI_HISM_IO_RD_FIFO_UNDERFLOW (1<<6)
/** Host Interrupt Status Mask bit : Data write FIFO overflow */ /* Host Interrupt Status Mask bit : Data write FIFO overflow */
#define IF_SPI_HISM_DATA_WR_FIFO_OVERFLOW (1<<7) #define IF_SPI_HISM_DATA_WR_FIFO_OVERFLOW (1<<7)
/** Host Interrupt Status Mask bit : Data write FIFO underflow */ /* Host Interrupt Status Mask bit : Data write FIFO underflow */
#define IF_SPI_HISM_DATA_RD_FIFO_UNDERFLOW (1<<8) #define IF_SPI_HISM_DATA_RD_FIFO_UNDERFLOW (1<<8)
/** Host Interrupt Status Mask bit : Command write FIFO overflow */ /* Host Interrupt Status Mask bit : Command write FIFO overflow */
#define IF_SPI_HISM_CMD_WR_FIFO_OVERFLOW (1<<9) #define IF_SPI_HISM_CMD_WR_FIFO_OVERFLOW (1<<9)
/** Host Interrupt Status Mask bit : Command write FIFO underflow */ /* Host Interrupt Status Mask bit : Command write FIFO underflow */
#define IF_SPI_HISM_CMD_RD_FIFO_UNDERFLOW (1<<10) #define IF_SPI_HISM_CMD_RD_FIFO_UNDERFLOW (1<<10)
/***************** IF_SPI_SPU_BUS_MODE_REG *****************/ /***************** IF_SPI_SPU_BUS_MODE_REG *****************/
......
/** /*
* This file contains functions used in USB interface module. * This file contains functions used in USB interface module.
*/ */
#include <linux/delay.h> #include <linux/delay.h>
...@@ -66,7 +66,7 @@ static int if_usb_reset_device(struct if_usb_card *cardp); ...@@ -66,7 +66,7 @@ static int if_usb_reset_device(struct if_usb_card *cardp);
/* sysfs hooks */ /* sysfs hooks */
/** /*
* Set function to write firmware to device's persistent memory * Set function to write firmware to device's persistent memory
*/ */
static ssize_t if_usb_firmware_set(struct device *dev, static ssize_t if_usb_firmware_set(struct device *dev,
...@@ -85,7 +85,7 @@ static ssize_t if_usb_firmware_set(struct device *dev, ...@@ -85,7 +85,7 @@ static ssize_t if_usb_firmware_set(struct device *dev,
return ret; return ret;
} }
/** /*
* lbs_flash_fw attribute to be exported per ethX interface through sysfs * lbs_flash_fw attribute to be exported per ethX interface through sysfs
* (/sys/class/net/ethX/lbs_flash_fw). Use this like so to write firmware to * (/sys/class/net/ethX/lbs_flash_fw). Use this like so to write firmware to
* the device's persistent memory: * the device's persistent memory:
...@@ -94,7 +94,14 @@ static ssize_t if_usb_firmware_set(struct device *dev, ...@@ -94,7 +94,14 @@ static ssize_t if_usb_firmware_set(struct device *dev,
static DEVICE_ATTR(lbs_flash_fw, 0200, NULL, if_usb_firmware_set); static DEVICE_ATTR(lbs_flash_fw, 0200, NULL, if_usb_firmware_set);
/** /**
* Set function to write firmware to device's persistent memory * if_usb_boot2_set - write firmware to device's persistent memory
*
* @dev: target device
* @attr: device attributes
* @buf: firmware buffer to write
* @count: number of bytes to write
*
* returns: number of bytes written or negative error code
*/ */
static ssize_t if_usb_boot2_set(struct device *dev, static ssize_t if_usb_boot2_set(struct device *dev,
struct device_attribute *attr, const char *buf, size_t count) struct device_attribute *attr, const char *buf, size_t count)
...@@ -112,7 +119,7 @@ static ssize_t if_usb_boot2_set(struct device *dev, ...@@ -112,7 +119,7 @@ static ssize_t if_usb_boot2_set(struct device *dev,
return ret; return ret;
} }
/** /*
* lbs_flash_boot2 attribute to be exported per ethX interface through sysfs * lbs_flash_boot2 attribute to be exported per ethX interface through sysfs
* (/sys/class/net/ethX/lbs_flash_boot2). Use this like so to write firmware * (/sys/class/net/ethX/lbs_flash_boot2). Use this like so to write firmware
* to the device's persistent memory: * to the device's persistent memory:
...@@ -121,9 +128,10 @@ static ssize_t if_usb_boot2_set(struct device *dev, ...@@ -121,9 +128,10 @@ static ssize_t if_usb_boot2_set(struct device *dev,
static DEVICE_ATTR(lbs_flash_boot2, 0200, NULL, if_usb_boot2_set); static DEVICE_ATTR(lbs_flash_boot2, 0200, NULL, if_usb_boot2_set);
/** /**
* @brief call back function to handle the status of the URB * if_usb_write_bulk_callback - callback function to handle the status
* @param urb pointer to urb structure * of the URB
* @return N/A * @urb: pointer to &urb structure
* returns: N/A
*/ */
static void if_usb_write_bulk_callback(struct urb *urb) static void if_usb_write_bulk_callback(struct urb *urb)
{ {
...@@ -150,9 +158,9 @@ static void if_usb_write_bulk_callback(struct urb *urb) ...@@ -150,9 +158,9 @@ static void if_usb_write_bulk_callback(struct urb *urb)
} }
/** /**
* @brief free tx/rx urb, skb and rx buffer * if_usb_free - free tx/rx urb, skb and rx buffer
* @param cardp pointer if_usb_card * @cardp: pointer to &if_usb_card
* @return N/A * returns: N/A
*/ */
static void if_usb_free(struct if_usb_card *cardp) static void if_usb_free(struct if_usb_card *cardp)
{ {
...@@ -231,10 +239,10 @@ static void if_usb_reset_olpc_card(struct lbs_private *priv) ...@@ -231,10 +239,10 @@ static void if_usb_reset_olpc_card(struct lbs_private *priv)
#endif #endif
/** /**
* @brief sets the configuration values * if_usb_probe - sets the configuration values
* @param ifnum interface number * @intf: &usb_interface pointer
* @param id pointer to usb_device_id * @id: pointer to usb_device_id
* @return 0 on success, error code on failure * returns: 0 on success, error code on failure
*/ */
static int if_usb_probe(struct usb_interface *intf, static int if_usb_probe(struct usb_interface *intf,
const struct usb_device_id *id) const struct usb_device_id *id)
...@@ -366,9 +374,9 @@ static int if_usb_probe(struct usb_interface *intf, ...@@ -366,9 +374,9 @@ static int if_usb_probe(struct usb_interface *intf,
} }
/** /**
* @brief free resource and cleanup * if_usb_disconnect - free resource and cleanup
* @param intf USB interface structure * @intf: USB interface structure
* @return N/A * returns: N/A
*/ */
static void if_usb_disconnect(struct usb_interface *intf) static void if_usb_disconnect(struct usb_interface *intf)
{ {
...@@ -398,9 +406,9 @@ static void if_usb_disconnect(struct usb_interface *intf) ...@@ -398,9 +406,9 @@ static void if_usb_disconnect(struct usb_interface *intf)
} }
/** /**
* @brief This function download FW * if_usb_send_fw_pkt - download FW
* @param priv pointer to struct lbs_private * @cardp: pointer to &struct if_usb_card
* @return 0 * returns: 0
*/ */
static int if_usb_send_fw_pkt(struct if_usb_card *cardp) static int if_usb_send_fw_pkt(struct if_usb_card *cardp)
{ {
...@@ -486,11 +494,11 @@ static int if_usb_reset_device(struct if_usb_card *cardp) ...@@ -486,11 +494,11 @@ static int if_usb_reset_device(struct if_usb_card *cardp)
} }
/** /**
* @brief This function transfer the data to the device. * usb_tx_block - transfer the data to the device
* @param priv pointer to struct lbs_private * @cardp: pointer to &struct if_usb_card
* @param payload pointer to payload data * @payload: pointer to payload data
* @param nb data length * @nb: data length
* @return 0 or -1 * returns: 0 for success or negative error code
*/ */
static int usb_tx_block(struct if_usb_card *cardp, uint8_t *payload, uint16_t nb) static int usb_tx_block(struct if_usb_card *cardp, uint8_t *payload, uint16_t nb)
{ {
...@@ -727,11 +735,11 @@ static inline void process_cmdrequest(int recvlength, uint8_t *recvbuff, ...@@ -727,11 +735,11 @@ static inline void process_cmdrequest(int recvlength, uint8_t *recvbuff,
} }
/** /**
* @brief This function reads of the packet into the upload buff, * if_usb_receive - read the packet into the upload buffer,
* wake up the main thread and initialise the Rx callack. * wake up the main thread and initialise the Rx callack
* *
* @param urb pointer to struct urb * @urb: pointer to &struct urb
* @return N/A * returns: N/A
*/ */
static void if_usb_receive(struct urb *urb) static void if_usb_receive(struct urb *urb)
{ {
...@@ -802,12 +810,12 @@ static void if_usb_receive(struct urb *urb) ...@@ -802,12 +810,12 @@ static void if_usb_receive(struct urb *urb)
} }
/** /**
* @brief This function downloads data to FW * if_usb_host_to_card - downloads data to FW
* @param priv pointer to struct lbs_private structure * @priv: pointer to &struct lbs_private structure
* @param type type of data * @type: type of data
* @param buf pointer to data buffer * @payload: pointer to data buffer
* @param len number of bytes * @nb: number of bytes
* @return 0 or -1 * returns: 0 for success or negative error code
*/ */
static int if_usb_host_to_card(struct lbs_private *priv, uint8_t type, static int if_usb_host_to_card(struct lbs_private *priv, uint8_t type,
uint8_t *payload, uint16_t nb) uint8_t *payload, uint16_t nb)
...@@ -831,10 +839,11 @@ static int if_usb_host_to_card(struct lbs_private *priv, uint8_t type, ...@@ -831,10 +839,11 @@ static int if_usb_host_to_card(struct lbs_private *priv, uint8_t type,
} }
/** /**
* @brief This function issues Boot command to the Boot2 code * if_usb_issue_boot_command - issues Boot command to the Boot2 code
* @param ivalue 1:Boot from FW by USB-Download * @cardp: pointer to &if_usb_card
* @ivalue: 1:Boot from FW by USB-Download
* 2:Boot from FW in EEPROM * 2:Boot from FW in EEPROM
* @return 0 * returns: 0 for success or negative error code
*/ */
static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue) static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue)
{ {
...@@ -853,11 +862,11 @@ static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue) ...@@ -853,11 +862,11 @@ static int if_usb_issue_boot_command(struct if_usb_card *cardp, int ivalue)
/** /**
* @brief This function checks the validity of Boot2/FW image. * check_fwfile_format - check the validity of Boot2/FW image
* *
* @param data pointer to image * @data: pointer to image
* len image length * @totlen: image length
* @return 0 or -1 * returns: 0 (good) or 1 (failure)
*/ */
static int check_fwfile_format(const uint8_t *data, uint32_t totlen) static int check_fwfile_format(const uint8_t *data, uint32_t totlen)
{ {
...@@ -901,13 +910,13 @@ static int check_fwfile_format(const uint8_t *data, uint32_t totlen) ...@@ -901,13 +910,13 @@ static int check_fwfile_format(const uint8_t *data, uint32_t totlen)
/** /**
* @brief This function programs the firmware subject to cmd * if_usb_prog_firmware - programs the firmware subject to cmd
* *
* @param cardp the if_usb_card descriptor * @cardp: the if_usb_card descriptor
* fwname firmware or boot2 image file name * @fwname: firmware or boot2 image file name
* cmd either BOOT_CMD_FW_BY_USB, BOOT_CMD_UPDATE_FW, * @cmd: either BOOT_CMD_FW_BY_USB, BOOT_CMD_UPDATE_FW,
* or BOOT_CMD_UPDATE_BOOT2. * or BOOT_CMD_UPDATE_BOOT2.
* @return 0 or error code * returns: 0 or error code
*/ */
static int if_usb_prog_firmware(struct if_usb_card *cardp, static int if_usb_prog_firmware(struct if_usb_card *cardp,
const char *fwname, int cmd) const char *fwname, int cmd)
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
struct lbs_private; struct lbs_private;
/** /*
* This file contains definition for USB interface. * This file contains definition for USB interface.
*/ */
#define CMD_TYPE_REQUEST 0xF00DFACE #define CMD_TYPE_REQUEST 0xF00DFACE
...@@ -40,7 +40,7 @@ struct bootcmdresp ...@@ -40,7 +40,7 @@ struct bootcmdresp
uint8_t pad[2]; uint8_t pad[2];
}; };
/** USB card description structure*/ /* USB card description structure*/
struct if_usb_card { struct if_usb_card {
struct usb_device *udev; struct usb_device *udev;
uint32_t model; /* MODEL_* */ uint32_t model; /* MODEL_* */
...@@ -77,7 +77,7 @@ struct if_usb_card { ...@@ -77,7 +77,7 @@ struct if_usb_card {
__le16 boot2_version; __le16 boot2_version;
}; };
/** fwheader */ /* fwheader */
struct fwheader { struct fwheader {
__le32 dnldcmd; __le32 dnldcmd;
__le32 baseaddr; __le32 baseaddr;
...@@ -86,14 +86,14 @@ struct fwheader { ...@@ -86,14 +86,14 @@ struct fwheader {
}; };
#define FW_MAX_DATA_BLK_SIZE 600 #define FW_MAX_DATA_BLK_SIZE 600
/** FWData */ /* FWData */
struct fwdata { struct fwdata {
struct fwheader hdr; struct fwheader hdr;
__le32 seqnum; __le32 seqnum;
uint8_t data[0]; uint8_t data[0];
}; };
/** fwsyncheader */ /* fwsyncheader */
struct fwsyncheader { struct fwsyncheader {
__le32 cmd; __le32 cmd;
__le32 seqnum; __le32 seqnum;
......
/** /*
* This file contains the major functions in WLAN * This file contains the major functions in WLAN
* driver. It includes init, exit, open, close and main * driver. It includes init, exit, open, close and main
* thread etc.. * thread etc..
...@@ -35,18 +35,20 @@ EXPORT_SYMBOL_GPL(lbs_debug); ...@@ -35,18 +35,20 @@ EXPORT_SYMBOL_GPL(lbs_debug);
module_param_named(libertas_debug, lbs_debug, int, 0644); module_param_named(libertas_debug, lbs_debug, int, 0644);
/* This global structure is used to send the confirm_sleep command as /*
* fast as possible down to the firmware. */ * This global structure is used to send the confirm_sleep command as
* fast as possible down to the firmware.
*/
struct cmd_confirm_sleep confirm_sleep; struct cmd_confirm_sleep confirm_sleep;
/** /*
* the table to keep region code * the table to keep region code
*/ */
u16 lbs_region_code_to_index[MRVDRV_MAX_REGION_CODE] = u16 lbs_region_code_to_index[MRVDRV_MAX_REGION_CODE] =
{ 0x10, 0x20, 0x30, 0x31, 0x32, 0x40 }; { 0x10, 0x20, 0x30, 0x31, 0x32, 0x40 };
/** /*
* FW rate table. FW refers to rates by their index in this table, not by the * FW rate table. FW refers to rates by their index in this table, not by the
* rate value itself. Values of 0x00 are * rate value itself. Values of 0x00 are
* reserved positions. * reserved positions.
...@@ -57,10 +59,10 @@ static u8 fw_data_rates[MAX_RATES] = ...@@ -57,10 +59,10 @@ static u8 fw_data_rates[MAX_RATES] =
}; };
/** /**
* @brief use index to get the data rate * lbs_fw_index_to_data_rate - use index to get the data rate
* *
* @param idx The index of data rate * @idx: The index of data rate
* @return data rate or 0 * returns: data rate or 0
*/ */
u32 lbs_fw_index_to_data_rate(u8 idx) u32 lbs_fw_index_to_data_rate(u8 idx)
{ {
...@@ -70,10 +72,10 @@ u32 lbs_fw_index_to_data_rate(u8 idx) ...@@ -70,10 +72,10 @@ u32 lbs_fw_index_to_data_rate(u8 idx)
} }
/** /**
* @brief use rate to get the index * lbs_data_rate_to_fw_index - use rate to get the index
* *
* @param rate data rate * @rate: data rate
* @return index or 0 * returns: index or 0
*/ */
u8 lbs_data_rate_to_fw_index(u32 rate) u8 lbs_data_rate_to_fw_index(u32 rate)
{ {
...@@ -91,10 +93,10 @@ u8 lbs_data_rate_to_fw_index(u32 rate) ...@@ -91,10 +93,10 @@ u8 lbs_data_rate_to_fw_index(u32 rate)
/** /**
* @brief This function opens the ethX interface * lbs_dev_open - open the ethX interface
* *
* @param dev A pointer to net_device structure * @dev: A pointer to &net_device structure
* @return 0 or -EBUSY if monitor mode active * returns: 0 or -EBUSY if monitor mode active
*/ */
static int lbs_dev_open(struct net_device *dev) static int lbs_dev_open(struct net_device *dev)
{ {
...@@ -120,10 +122,10 @@ static int lbs_dev_open(struct net_device *dev) ...@@ -120,10 +122,10 @@ static int lbs_dev_open(struct net_device *dev)
} }
/** /**
* @brief This function closes the ethX interface * lbs_eth_stop - close the ethX interface
* *
* @param dev A pointer to net_device structure * @dev: A pointer to &net_device structure
* @return 0 * returns: 0
*/ */
static int lbs_eth_stop(struct net_device *dev) static int lbs_eth_stop(struct net_device *dev)
{ {
...@@ -336,12 +338,12 @@ void lbs_set_multicast_list(struct net_device *dev) ...@@ -336,12 +338,12 @@ void lbs_set_multicast_list(struct net_device *dev)
} }
/** /**
* @brief This function handles the major jobs in the LBS driver. * lbs_thread - handles the major jobs in the LBS driver.
* It handles all events generated by firmware, RX data received * It handles all events generated by firmware, RX data received
* from firmware and TX data sent from kernel. * from firmware and TX data sent from kernel.
* *
* @param data A pointer to lbs_thread structure * @data: A pointer to &lbs_thread structure
* @return 0 * returns: 0
*/ */
static int lbs_thread(void *data) static int lbs_thread(void *data)
{ {
...@@ -540,11 +542,11 @@ static int lbs_thread(void *data) ...@@ -540,11 +542,11 @@ static int lbs_thread(void *data)
} }
/** /**
* @brief This function gets the HW spec from the firmware and sets * lbs_setup_firmware - gets the HW spec from the firmware and sets
* some basic parameters. * some basic parameters
* *
* @param priv A pointer to struct lbs_private structure * @priv: A pointer to &struct lbs_private structure
* @return 0 or -1 * returns: 0 or -1
*/ */
static int lbs_setup_firmware(struct lbs_private *priv) static int lbs_setup_firmware(struct lbs_private *priv)
{ {
...@@ -630,8 +632,10 @@ int lbs_resume(struct lbs_private *priv) ...@@ -630,8 +632,10 @@ int lbs_resume(struct lbs_private *priv)
EXPORT_SYMBOL_GPL(lbs_resume); EXPORT_SYMBOL_GPL(lbs_resume);
/** /**
* This function handles the timeout of command sending. * lbs_cmd_timeout_handler - handles the timeout of command sending.
* It will re-send the same command again. * It will re-send the same command again.
*
* @data: &struct lbs_private pointer
*/ */
static void lbs_cmd_timeout_handler(unsigned long data) static void lbs_cmd_timeout_handler(unsigned long data)
{ {
...@@ -655,8 +659,10 @@ static void lbs_cmd_timeout_handler(unsigned long data) ...@@ -655,8 +659,10 @@ static void lbs_cmd_timeout_handler(unsigned long data)
} }
/** /**
* This function put the device back to deep sleep mode when timer expires * auto_deepsleep_timer_fn - put the device back to deep sleep mode when
* and no activity (command, event, data etc.) is detected. * timer expires and no activity (command, event, data etc.) is detected.
* @data: &struct lbs_private pointer
* returns: N/A
*/ */
static void auto_deepsleep_timer_fn(unsigned long data) static void auto_deepsleep_timer_fn(unsigned long data)
{ {
...@@ -792,11 +798,12 @@ static const struct net_device_ops lbs_netdev_ops = { ...@@ -792,11 +798,12 @@ static const struct net_device_ops lbs_netdev_ops = {
}; };
/** /**
* @brief This function adds the card. it will probe the * lbs_add_card - adds the card. It will probe the
* card, allocate the lbs_priv and initialize the device. * card, allocate the lbs_priv and initialize the device.
* *
* @param card A pointer to card * @card: A pointer to card
* @return A pointer to struct lbs_private structure * @dmdev: A pointer to &struct device
* returns: A pointer to &struct lbs_private structure
*/ */
struct lbs_private *lbs_add_card(void *card, struct device *dmdev) struct lbs_private *lbs_add_card(void *card, struct device *dmdev)
{ {
...@@ -1057,19 +1064,19 @@ void lbs_notify_command_response(struct lbs_private *priv, u8 resp_idx) ...@@ -1057,19 +1064,19 @@ void lbs_notify_command_response(struct lbs_private *priv, u8 resp_idx)
EXPORT_SYMBOL_GPL(lbs_notify_command_response); EXPORT_SYMBOL_GPL(lbs_notify_command_response);
/** /**
* @brief Retrieves two-stage firmware * lbs_get_firmware - Retrieves two-stage firmware
* *
* @param dev A pointer to device structure * @dev: A pointer to &device structure
* @param user_helper User-defined helper firmware file * @user_helper: User-defined helper firmware file
* @param user_mainfw User-defined main firmware file * @user_mainfw: User-defined main firmware file
* @param card_model Bus-specific card model ID used to filter firmware table * @card_model: Bus-specific card model ID used to filter firmware table
* elements * elements
* @param fw_table Table of firmware file names and device model numbers * @fw_table: Table of firmware file names and device model numbers
* terminated by an entry with a NULL helper name * terminated by an entry with a NULL helper name
* @param helper On success, the helper firmware; caller must free * @helper: On success, the helper firmware; caller must free
* @param mainfw On success, the main firmware; caller must free * @mainfw: On success, the main firmware; caller must free
* *
* @return 0 on success, non-zero on failure * returns: 0 on success, non-zero on failure
*/ */
int lbs_get_firmware(struct device *dev, const char *user_helper, int lbs_get_firmware(struct device *dev, const char *user_helper,
const char *user_mainfw, u32 card_model, const char *user_mainfw, u32 card_model,
......
This diff is collapsed.
/** /*
* Contains all definitions needed for the Libertas' MESH implementation. * Contains all definitions needed for the Libertas' MESH implementation.
*/ */
#ifndef _LBS_MESH_H_ #ifndef _LBS_MESH_H_
......
/** /*
* This file contains the handling of RX in wlan driver. * This file contains the handling of RX in wlan driver.
*/ */
#include <linux/etherdevice.h> #include <linux/etherdevice.h>
...@@ -40,12 +40,12 @@ static int process_rxed_802_11_packet(struct lbs_private *priv, ...@@ -40,12 +40,12 @@ static int process_rxed_802_11_packet(struct lbs_private *priv,
struct sk_buff *skb); struct sk_buff *skb);
/** /**
* @brief This function processes received packet and forwards it * lbs_process_rxed_packet - processes received packet and forwards it
* to kernel/upper layer * to kernel/upper layer
* *
* @param priv A pointer to struct lbs_private * @priv: A pointer to &struct lbs_private
* @param skb A pointer to skb which includes the received packet * @skb: A pointer to skb which includes the received packet
* @return 0 or -1 * returns: 0 or -1
*/ */
int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *skb) int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *skb)
{ {
...@@ -156,11 +156,11 @@ int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *skb) ...@@ -156,11 +156,11 @@ int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *skb)
EXPORT_SYMBOL_GPL(lbs_process_rxed_packet); EXPORT_SYMBOL_GPL(lbs_process_rxed_packet);
/** /**
* @brief This function converts Tx/Rx rates from the Marvell WLAN format * convert_mv_rate_to_radiotap - converts Tx/Rx rates from Marvell WLAN format
* (see Table 2 in Section 3.1) to IEEE80211_RADIOTAP_RATE units (500 Kb/s) * (see Table 2 in Section 3.1) to IEEE80211_RADIOTAP_RATE units (500 Kb/s)
* *
* @param rate Input rate * @rate: Input rate
* @return Output Rate (0 if invalid) * returns: Output Rate (0 if invalid)
*/ */
static u8 convert_mv_rate_to_radiotap(u8 rate) static u8 convert_mv_rate_to_radiotap(u8 rate)
{ {
...@@ -196,12 +196,12 @@ static u8 convert_mv_rate_to_radiotap(u8 rate) ...@@ -196,12 +196,12 @@ static u8 convert_mv_rate_to_radiotap(u8 rate)
} }
/** /**
* @brief This function processes a received 802.11 packet and forwards it * process_rxed_802_11_packet - processes a received 802.11 packet and forwards
* to kernel/upper layer * it to kernel/upper layer
* *
* @param priv A pointer to struct lbs_private * @priv: A pointer to &struct lbs_private
* @param skb A pointer to skb which includes the received packet * @skb: A pointer to skb which includes the received packet
* @return 0 or -1 * returns: 0 or -1
*/ */
static int process_rxed_802_11_packet(struct lbs_private *priv, static int process_rxed_802_11_packet(struct lbs_private *priv,
struct sk_buff *skb) struct sk_buff *skb)
......
/** /*
* This file contains the handling of TX in wlan driver. * This file contains the handling of TX in wlan driver.
*/ */
#include <linux/netdevice.h> #include <linux/netdevice.h>
...@@ -13,11 +13,11 @@ ...@@ -13,11 +13,11 @@
#include "dev.h" #include "dev.h"
/** /**
* @brief This function converts Tx/Rx rates from IEEE80211_RADIOTAP_RATE * convert_radiotap_rate_to_mv - converts Tx/Rx rates from IEEE80211_RADIOTAP_RATE
* units (500 Kb/s) into Marvell WLAN format (see Table 8 in Section 3.2.1) * units (500 Kb/s) into Marvell WLAN format (see Table 8 in Section 3.2.1)
* *
* @param rate Input rate * @rate: Input rate
* @return Output Rate (0 if invalid) * returns: Output Rate (0 if invalid)
*/ */
static u32 convert_radiotap_rate_to_mv(u8 rate) static u32 convert_radiotap_rate_to_mv(u8 rate)
{ {
...@@ -51,12 +51,12 @@ static u32 convert_radiotap_rate_to_mv(u8 rate) ...@@ -51,12 +51,12 @@ static u32 convert_radiotap_rate_to_mv(u8 rate)
} }
/** /**
* @brief This function checks the conditions and sends packet to IF * lbs_hard_start_xmit - checks the conditions and sends packet to IF
* layer if everything is ok. * layer if everything is ok
* *
* @param priv A pointer to struct lbs_private structure * @skb: A pointer to skb which includes TX packet
* @param skb A pointer to skb which includes TX packet * @dev: A pointer to the &struct net_device
* @return 0 or -1 * returns: 0 or -1
*/ */
netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
{ {
...@@ -168,13 +168,13 @@ netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev) ...@@ -168,13 +168,13 @@ netdev_tx_t lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev)
} }
/** /**
* @brief This function sends to the host the last transmitted packet, * lbs_send_tx_feedback - sends to the host the last transmitted packet,
* filling the radiotap headers with transmission information. * filling the radiotap headers with transmission information.
* *
* @param priv A pointer to struct lbs_private structure * @priv: A pointer to &struct lbs_private structure
* @param status A 32 bit value containing transmission status. * @try_count: A 32-bit value containing transmission retry status.
* *
* @returns void * returns: void
*/ */
void lbs_send_tx_feedback(struct lbs_private *priv, u32 try_count) void lbs_send_tx_feedback(struct lbs_private *priv, u32 try_count)
{ {
......
/** /*
* This header file contains definition for global types * This header file contains definition for global types
*/ */
#ifndef _LBS_TYPES_H_ #ifndef _LBS_TYPES_H_
...@@ -54,7 +54,7 @@ union ieee_phy_param_set { ...@@ -54,7 +54,7 @@ union ieee_phy_param_set {
struct ieee_ie_ds_param_set ds; struct ieee_ie_ds_param_set ds;
} __packed; } __packed;
/** TLV type ID definition */ /* TLV type ID definition */
#define PROPRIETARY_TLV_BASE_ID 0x0100 #define PROPRIETARY_TLV_BASE_ID 0x0100
/* Terminating TLV type */ /* Terminating TLV type */
...@@ -96,7 +96,7 @@ union ieee_phy_param_set { ...@@ -96,7 +96,7 @@ union ieee_phy_param_set {
#define TLV_TYPE_MESH_ID (PROPRIETARY_TLV_BASE_ID + 37) #define TLV_TYPE_MESH_ID (PROPRIETARY_TLV_BASE_ID + 37)
#define TLV_TYPE_OLD_MESH_ID (PROPRIETARY_TLV_BASE_ID + 291) #define TLV_TYPE_OLD_MESH_ID (PROPRIETARY_TLV_BASE_ID + 291)
/** TLV related data structures*/ /* TLV related data structures */
struct mrvl_ie_header { struct mrvl_ie_header {
__le16 type; __le16 type;
__le16 len; __le16 len;
...@@ -177,7 +177,7 @@ struct mrvl_ie_auth_type { ...@@ -177,7 +177,7 @@ struct mrvl_ie_auth_type {
__le16 auth; __le16 auth;
} __packed; } __packed;
/** Local Power capability */ /* Local Power capability */
struct mrvl_ie_power_capability { struct mrvl_ie_power_capability {
struct mrvl_ie_header header; struct mrvl_ie_header header;
s8 minpower; s8 minpower;
...@@ -235,9 +235,11 @@ struct mrvl_ie_ledbhv { ...@@ -235,9 +235,11 @@ struct mrvl_ie_ledbhv {
struct led_bhv ledbhv[1]; struct led_bhv ledbhv[1];
} __packed; } __packed;
/* Meant to be packed as the value member of a struct ieee80211_info_element. /*
* Meant to be packed as the value member of a struct ieee80211_info_element.
* Note that the len member of the ieee80211_info_element varies depending on * Note that the len member of the ieee80211_info_element varies depending on
* the mesh_id_len */ * the mesh_id_len
*/
struct mrvl_meshie_val { struct mrvl_meshie_val {
uint8_t oui[3]; uint8_t oui[3];
uint8_t type; uint8_t type;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment