4f67949656
Make it take struct lbs_private as argument; that's all it wants anyway, and all callers were starting off from that. Don't wake the netif queues, because those should be handled elsewhere. And sort out the locking, with a big nasty warning for those who don't have the driver_lock locked when they call it. Oh, and fix if_cs.c to lock the driver_lock before calling it. Signed-off-by: David Woodhouse <dwmw2@infradead.org> Signed-off-by: John W. Linville <linville@tuxdriver.com>
87 lines
2.6 KiB
C
87 lines
2.6 KiB
C
/**
|
|
* This file contains declaration referring to
|
|
* functions defined in other source files
|
|
*/
|
|
|
|
#ifndef _LBS_DECL_H_
|
|
#define _LBS_DECL_H_
|
|
|
|
#include <linux/device.h>
|
|
|
|
#include "defs.h"
|
|
|
|
/** Function Prototype Declaration */
|
|
struct lbs_private;
|
|
struct sk_buff;
|
|
struct net_device;
|
|
struct cmd_ctrl_node;
|
|
struct cmd_ds_command;
|
|
|
|
int lbs_set_mac_packet_filter(struct lbs_private *priv);
|
|
|
|
void lbs_send_tx_feedback(struct lbs_private *priv);
|
|
|
|
int lbs_free_cmd_buffer(struct lbs_private *priv);
|
|
|
|
int lbs_cmd(struct lbs_private *priv, uint16_t command, void *cmd, int cmd_size,
|
|
int (*callback)(struct lbs_private *, unsigned long, struct cmd_ds_command *),
|
|
unsigned long callback_arg);
|
|
|
|
int lbs_prepare_and_send_command(struct lbs_private *priv,
|
|
u16 cmd_no,
|
|
u16 cmd_action,
|
|
u16 wait_option, u32 cmd_oid, void *pdata_buf);
|
|
|
|
void lbs_queue_cmd(struct lbs_private *priv,
|
|
struct cmd_ctrl_node *cmdnode,
|
|
u8 addtail);
|
|
|
|
int lbs_allocate_cmd_buffer(struct lbs_private *priv);
|
|
int lbs_execute_next_command(struct lbs_private *priv);
|
|
int lbs_process_event(struct lbs_private *priv);
|
|
void lbs_interrupt(struct lbs_private *priv);
|
|
int lbs_set_radio_control(struct lbs_private *priv);
|
|
u32 lbs_fw_index_to_data_rate(u8 index);
|
|
u8 lbs_data_rate_to_fw_index(u32 rate);
|
|
void lbs_get_fwversion(struct lbs_private *priv,
|
|
char *fwversion,
|
|
int maxlen);
|
|
|
|
/** The proc fs interface */
|
|
int lbs_process_rx_command(struct lbs_private *priv);
|
|
void __lbs_cleanup_and_insert_cmd(struct lbs_private *priv,
|
|
struct cmd_ctrl_node *ptempcmd);
|
|
|
|
int lbs_hard_start_xmit(struct sk_buff *skb, struct net_device *dev);
|
|
int lbs_set_regiontable(struct lbs_private *priv, u8 region, u8 band);
|
|
|
|
int lbs_process_rxed_packet(struct lbs_private *priv, struct sk_buff *);
|
|
|
|
void lbs_ps_sleep(struct lbs_private *priv, int wait_option);
|
|
void lbs_ps_confirm_sleep(struct lbs_private *priv, u16 psmode);
|
|
void lbs_ps_wakeup(struct lbs_private *priv, int wait_option);
|
|
|
|
struct chan_freq_power *lbs_find_cfp_by_band_and_channel(
|
|
struct lbs_private *priv,
|
|
u8 band,
|
|
u16 channel);
|
|
|
|
void lbs_mac_event_disconnected(struct lbs_private *priv);
|
|
|
|
void lbs_send_iwevcustom_event(struct lbs_private *priv, s8 *str);
|
|
|
|
/* main.c */
|
|
struct chan_freq_power *lbs_get_region_cfp_table(u8 region,
|
|
u8 band,
|
|
int *cfp_no);
|
|
struct lbs_private *lbs_add_card(void *card, struct device *dmdev);
|
|
int lbs_remove_card(struct lbs_private *priv);
|
|
int lbs_start_card(struct lbs_private *priv);
|
|
int lbs_stop_card(struct lbs_private *priv);
|
|
int lbs_add_mesh(struct lbs_private *priv, struct device *dev);
|
|
void lbs_remove_mesh(struct lbs_private *priv);
|
|
int lbs_reset_device(struct lbs_private *priv);
|
|
void lbs_host_to_card_done(struct lbs_private *priv);
|
|
|
|
#endif
|