#include <linux/crc-itu-t.h>
#include <linux/delay.h>
#include <linux/etherdevice.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/slab.h>
#include <linux/pci.h>
#include <linux/eeprom_93cx6.h>
#include "rt2x00.h"
#include "rt2x00mmio.h"
#include "rt2x00pci.h"
#include "rt61pci.h"
static bool modparam_nohwcrypt = …;
module_param_named(nohwcrypt, modparam_nohwcrypt, bool, 0444);
MODULE_PARM_DESC(…) …;
#define WAIT_FOR_BBP(__dev, __reg) …
#define WAIT_FOR_RF(__dev, __reg) …
#define WAIT_FOR_MCU(__dev, __reg) …
static void rt61pci_bbp_write(struct rt2x00_dev *rt2x00dev,
const unsigned int word, const u8 value)
{ … }
static u8 rt61pci_bbp_read(struct rt2x00_dev *rt2x00dev,
const unsigned int word)
{ … }
static void rt61pci_rf_write(struct rt2x00_dev *rt2x00dev,
const unsigned int word, const u32 value)
{ … }
static void rt61pci_mcu_request(struct rt2x00_dev *rt2x00dev,
const u8 command, const u8 token,
const u8 arg0, const u8 arg1)
{ … }
static void rt61pci_eepromregister_read(struct eeprom_93cx6 *eeprom)
{ … }
static void rt61pci_eepromregister_write(struct eeprom_93cx6 *eeprom)
{ … }
#ifdef CONFIG_RT2X00_LIB_DEBUGFS
static const struct rt2x00debug rt61pci_rt2x00debug = …;
#endif
static int rt61pci_rfkill_poll(struct rt2x00_dev *rt2x00dev)
{ … }
#ifdef CONFIG_RT2X00_LIB_LEDS
static void rt61pci_brightness_set(struct led_classdev *led_cdev,
enum led_brightness brightness)
{ … }
static int rt61pci_blink_set(struct led_classdev *led_cdev,
unsigned long *delay_on,
unsigned long *delay_off)
{ … }
static void rt61pci_init_led(struct rt2x00_dev *rt2x00dev,
struct rt2x00_led *led,
enum led_type type)
{ … }
#endif
static int rt61pci_config_shared_key(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_crypto *crypto,
struct ieee80211_key_conf *key)
{ … }
static int rt61pci_config_pairwise_key(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_crypto *crypto,
struct ieee80211_key_conf *key)
{ … }
static void rt61pci_config_filter(struct rt2x00_dev *rt2x00dev,
const unsigned int filter_flags)
{ … }
static void rt61pci_config_intf(struct rt2x00_dev *rt2x00dev,
struct rt2x00_intf *intf,
struct rt2x00intf_conf *conf,
const unsigned int flags)
{ … }
static void rt61pci_config_erp(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_erp *erp,
u32 changed)
{ … }
static void rt61pci_config_antenna_5x(struct rt2x00_dev *rt2x00dev,
struct antenna_setup *ant)
{ … }
static void rt61pci_config_antenna_2x(struct rt2x00_dev *rt2x00dev,
struct antenna_setup *ant)
{ … }
static void rt61pci_config_antenna_2529_rx(struct rt2x00_dev *rt2x00dev,
const int p1, const int p2)
{ … }
static void rt61pci_config_antenna_2529(struct rt2x00_dev *rt2x00dev,
struct antenna_setup *ant)
{ … }
struct antenna_sel { … };
static const struct antenna_sel antenna_sel_a[] = …;
static const struct antenna_sel antenna_sel_bg[] = …;
static void rt61pci_config_ant(struct rt2x00_dev *rt2x00dev,
struct antenna_setup *ant)
{ … }
static void rt61pci_config_lna_gain(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_conf *libconf)
{ … }
static void rt61pci_config_channel(struct rt2x00_dev *rt2x00dev,
struct rf_channel *rf, const int txpower)
{ … }
static void rt61pci_config_txpower(struct rt2x00_dev *rt2x00dev,
const int txpower)
{ … }
static void rt61pci_config_retry_limit(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_conf *libconf)
{ … }
static void rt61pci_config_ps(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_conf *libconf)
{ … }
static void rt61pci_config(struct rt2x00_dev *rt2x00dev,
struct rt2x00lib_conf *libconf,
const unsigned int flags)
{ … }
static void rt61pci_link_stats(struct rt2x00_dev *rt2x00dev,
struct link_qual *qual)
{ … }
static inline void rt61pci_set_vgc(struct rt2x00_dev *rt2x00dev,
struct link_qual *qual, u8 vgc_level)
{ … }
static void rt61pci_reset_tuner(struct rt2x00_dev *rt2x00dev,
struct link_qual *qual)
{ … }
static void rt61pci_link_tuner(struct rt2x00_dev *rt2x00dev,
struct link_qual *qual, const u32 count)
{ … }
static void rt61pci_start_queue(struct data_queue *queue)
{ … }
static void rt61pci_kick_queue(struct data_queue *queue)
{ … }
static void rt61pci_stop_queue(struct data_queue *queue)
{ … }
static char *rt61pci_get_firmware_name(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_check_firmware(struct rt2x00_dev *rt2x00dev,
const u8 *data, const size_t len)
{ … }
static int rt61pci_load_firmware(struct rt2x00_dev *rt2x00dev,
const u8 *data, const size_t len)
{ … }
static bool rt61pci_get_entry_state(struct queue_entry *entry)
{ … }
static void rt61pci_clear_entry(struct queue_entry *entry)
{ … }
static int rt61pci_init_queues(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_init_registers(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_wait_bbp_ready(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_init_bbp(struct rt2x00_dev *rt2x00dev)
{ … }
static void rt61pci_toggle_irq(struct rt2x00_dev *rt2x00dev,
enum dev_state state)
{ … }
static int rt61pci_enable_radio(struct rt2x00_dev *rt2x00dev)
{ … }
static void rt61pci_disable_radio(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_set_state(struct rt2x00_dev *rt2x00dev, enum dev_state state)
{ … }
static int rt61pci_set_device_state(struct rt2x00_dev *rt2x00dev,
enum dev_state state)
{ … }
static void rt61pci_write_tx_desc(struct queue_entry *entry,
struct txentry_desc *txdesc)
{ … }
static void rt61pci_write_beacon(struct queue_entry *entry,
struct txentry_desc *txdesc)
{ … }
static void rt61pci_clear_beacon(struct queue_entry *entry)
{ … }
static int rt61pci_agc_to_rssi(struct rt2x00_dev *rt2x00dev, int rxd_w1)
{ … }
static void rt61pci_fill_rxdone(struct queue_entry *entry,
struct rxdone_entry_desc *rxdesc)
{ … }
static void rt61pci_txdone(struct rt2x00_dev *rt2x00dev)
{ … }
static void rt61pci_wakeup(struct rt2x00_dev *rt2x00dev)
{ … }
static inline void rt61pci_enable_interrupt(struct rt2x00_dev *rt2x00dev,
struct rt2x00_field32 irq_field)
{ … }
static void rt61pci_enable_mcu_interrupt(struct rt2x00_dev *rt2x00dev,
struct rt2x00_field32 irq_field)
{ … }
static void rt61pci_txstatus_tasklet(struct tasklet_struct *t)
{ … }
static void rt61pci_tbtt_tasklet(struct tasklet_struct *t)
{ … }
static void rt61pci_rxdone_tasklet(struct tasklet_struct *t)
{ … }
static void rt61pci_autowake_tasklet(struct tasklet_struct *t)
{ … }
static irqreturn_t rt61pci_interrupt(int irq, void *dev_instance)
{ … }
static int rt61pci_validate_eeprom(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_init_eeprom(struct rt2x00_dev *rt2x00dev)
{ … }
static const struct rf_channel rf_vals_noseq[] = …;
static const struct rf_channel rf_vals_seq[] = …;
static int rt61pci_probe_hw_mode(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_probe_hw(struct rt2x00_dev *rt2x00dev)
{ … }
static int rt61pci_conf_tx(struct ieee80211_hw *hw,
struct ieee80211_vif *vif,
unsigned int link_id, u16 queue_idx,
const struct ieee80211_tx_queue_params *params)
{ … }
static u64 rt61pci_get_tsf(struct ieee80211_hw *hw, struct ieee80211_vif *vif)
{ … }
static const struct ieee80211_ops rt61pci_mac80211_ops = …;
static const struct rt2x00lib_ops rt61pci_rt2x00_ops = …;
static void rt61pci_queue_init(struct data_queue *queue)
{ … }
static const struct rt2x00_ops rt61pci_ops = …;
static const struct pci_device_id rt61pci_device_table[] = …;
MODULE_AUTHOR(…);
MODULE_VERSION(…);
MODULE_DESCRIPTION(…) …;
MODULE_DEVICE_TABLE(pci, rt61pci_device_table);
MODULE_FIRMWARE(…);
MODULE_FIRMWARE(…);
MODULE_FIRMWARE(…);
MODULE_LICENSE(…) …;
static int rt61pci_probe(struct pci_dev *pci_dev,
const struct pci_device_id *id)
{ … }
static struct pci_driver rt61pci_driver = …;
module_pci_driver(…) …;