You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/linville/wireless-next-2.6
This commit is contained in:
@@ -445,9 +445,9 @@ static void adm8211_interrupt_rci(struct ieee80211_hw *dev)
|
||||
struct ieee80211_rx_status rx_status = {0};
|
||||
|
||||
if (priv->pdev->revision < ADM8211_REV_CA)
|
||||
rx_status.ssi = rssi;
|
||||
rx_status.signal = rssi;
|
||||
else
|
||||
rx_status.ssi = 100 - rssi;
|
||||
rx_status.signal = 100 - rssi;
|
||||
|
||||
rx_status.rate_idx = rate;
|
||||
|
||||
@@ -1893,9 +1893,10 @@ static int __devinit adm8211_probe(struct pci_dev *pdev,
|
||||
|
||||
dev->extra_tx_headroom = sizeof(struct adm8211_tx_hdr);
|
||||
/* dev->flags = IEEE80211_HW_RX_INCLUDES_FCS in promisc mode */
|
||||
dev->flags = IEEE80211_HW_SIGNAL_UNSPEC;
|
||||
|
||||
dev->channel_change_time = 1000;
|
||||
dev->max_rssi = 100; /* FIXME: find better value */
|
||||
dev->max_signal = 100; /* FIXME: find better value */
|
||||
|
||||
dev->queues = 1; /* ADM8211C supports more, maybe ADM8211B too */
|
||||
|
||||
|
||||
+29
-28
@@ -1148,7 +1148,6 @@ static u8 airo_dbm_to_pct (tdsRssiEntry *rssi_rid, u8 dbm);
|
||||
static void airo_networks_free(struct airo_info *ai);
|
||||
|
||||
struct airo_info {
|
||||
struct net_device_stats stats;
|
||||
struct net_device *dev;
|
||||
struct list_head dev_list;
|
||||
/* Note, we can have MAX_FIDS outstanding. FIDs are 16-bits, so we
|
||||
@@ -1924,7 +1923,7 @@ static int mpi_start_xmit(struct sk_buff *skb, struct net_device *dev) {
|
||||
if (npacks >= MAXTXQ - 1) {
|
||||
netif_stop_queue (dev);
|
||||
if (npacks > MAXTXQ) {
|
||||
ai->stats.tx_fifo_errors++;
|
||||
dev->stats.tx_fifo_errors++;
|
||||
return 1;
|
||||
}
|
||||
skb_queue_tail (&ai->txq, skb);
|
||||
@@ -2044,13 +2043,13 @@ static void get_tx_error(struct airo_info *ai, s32 fid)
|
||||
bap_read(ai, &status, 2, BAP0);
|
||||
}
|
||||
if (le16_to_cpu(status) & 2) /* Too many retries */
|
||||
ai->stats.tx_aborted_errors++;
|
||||
ai->dev->stats.tx_aborted_errors++;
|
||||
if (le16_to_cpu(status) & 4) /* Transmit lifetime exceeded */
|
||||
ai->stats.tx_heartbeat_errors++;
|
||||
ai->dev->stats.tx_heartbeat_errors++;
|
||||
if (le16_to_cpu(status) & 8) /* Aid fail */
|
||||
{ }
|
||||
if (le16_to_cpu(status) & 0x10) /* MAC disabled */
|
||||
ai->stats.tx_carrier_errors++;
|
||||
ai->dev->stats.tx_carrier_errors++;
|
||||
if (le16_to_cpu(status) & 0x20) /* Association lost */
|
||||
{ }
|
||||
/* We produce a TXDROP event only for retry or lifetime
|
||||
@@ -2102,7 +2101,7 @@ static void airo_end_xmit(struct net_device *dev) {
|
||||
for (; i < MAX_FIDS / 2 && (priv->fids[i] & 0xffff0000); i++);
|
||||
} else {
|
||||
priv->fids[fid] &= 0xffff;
|
||||
priv->stats.tx_window_errors++;
|
||||
dev->stats.tx_window_errors++;
|
||||
}
|
||||
if (i < MAX_FIDS / 2)
|
||||
netif_wake_queue(dev);
|
||||
@@ -2128,7 +2127,7 @@ static int airo_start_xmit(struct sk_buff *skb, struct net_device *dev) {
|
||||
netif_stop_queue(dev);
|
||||
|
||||
if (i == MAX_FIDS / 2) {
|
||||
priv->stats.tx_fifo_errors++;
|
||||
dev->stats.tx_fifo_errors++;
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
@@ -2167,7 +2166,7 @@ static void airo_end_xmit11(struct net_device *dev) {
|
||||
for (; i < MAX_FIDS && (priv->fids[i] & 0xffff0000); i++);
|
||||
} else {
|
||||
priv->fids[fid] &= 0xffff;
|
||||
priv->stats.tx_window_errors++;
|
||||
dev->stats.tx_window_errors++;
|
||||
}
|
||||
if (i < MAX_FIDS)
|
||||
netif_wake_queue(dev);
|
||||
@@ -2199,7 +2198,7 @@ static int airo_start_xmit11(struct sk_buff *skb, struct net_device *dev) {
|
||||
netif_stop_queue(dev);
|
||||
|
||||
if (i == MAX_FIDS) {
|
||||
priv->stats.tx_fifo_errors++;
|
||||
dev->stats.tx_fifo_errors++;
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
@@ -2219,8 +2218,9 @@ static int airo_start_xmit11(struct sk_buff *skb, struct net_device *dev) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void airo_read_stats(struct airo_info *ai)
|
||||
static void airo_read_stats(struct net_device *dev)
|
||||
{
|
||||
struct airo_info *ai = dev->priv;
|
||||
StatsRid stats_rid;
|
||||
__le32 *vals = stats_rid.vals;
|
||||
|
||||
@@ -2232,23 +2232,24 @@ static void airo_read_stats(struct airo_info *ai)
|
||||
readStatsRid(ai, &stats_rid, RID_STATS, 0);
|
||||
up(&ai->sem);
|
||||
|
||||
ai->stats.rx_packets = le32_to_cpu(vals[43]) + le32_to_cpu(vals[44]) +
|
||||
dev->stats.rx_packets = le32_to_cpu(vals[43]) + le32_to_cpu(vals[44]) +
|
||||
le32_to_cpu(vals[45]);
|
||||
ai->stats.tx_packets = le32_to_cpu(vals[39]) + le32_to_cpu(vals[40]) +
|
||||
dev->stats.tx_packets = le32_to_cpu(vals[39]) + le32_to_cpu(vals[40]) +
|
||||
le32_to_cpu(vals[41]);
|
||||
ai->stats.rx_bytes = le32_to_cpu(vals[92]);
|
||||
ai->stats.tx_bytes = le32_to_cpu(vals[91]);
|
||||
ai->stats.rx_errors = le32_to_cpu(vals[0]) + le32_to_cpu(vals[2]) +
|
||||
dev->stats.rx_bytes = le32_to_cpu(vals[92]);
|
||||
dev->stats.tx_bytes = le32_to_cpu(vals[91]);
|
||||
dev->stats.rx_errors = le32_to_cpu(vals[0]) + le32_to_cpu(vals[2]) +
|
||||
le32_to_cpu(vals[3]) + le32_to_cpu(vals[4]);
|
||||
ai->stats.tx_errors = le32_to_cpu(vals[42]) + ai->stats.tx_fifo_errors;
|
||||
ai->stats.multicast = le32_to_cpu(vals[43]);
|
||||
ai->stats.collisions = le32_to_cpu(vals[89]);
|
||||
dev->stats.tx_errors = le32_to_cpu(vals[42]) +
|
||||
dev->stats.tx_fifo_errors;
|
||||
dev->stats.multicast = le32_to_cpu(vals[43]);
|
||||
dev->stats.collisions = le32_to_cpu(vals[89]);
|
||||
|
||||
/* detailed rx_errors: */
|
||||
ai->stats.rx_length_errors = le32_to_cpu(vals[3]);
|
||||
ai->stats.rx_crc_errors = le32_to_cpu(vals[4]);
|
||||
ai->stats.rx_frame_errors = le32_to_cpu(vals[2]);
|
||||
ai->stats.rx_fifo_errors = le32_to_cpu(vals[0]);
|
||||
dev->stats.rx_length_errors = le32_to_cpu(vals[3]);
|
||||
dev->stats.rx_crc_errors = le32_to_cpu(vals[4]);
|
||||
dev->stats.rx_frame_errors = le32_to_cpu(vals[2]);
|
||||
dev->stats.rx_fifo_errors = le32_to_cpu(vals[0]);
|
||||
}
|
||||
|
||||
static struct net_device_stats *airo_get_stats(struct net_device *dev)
|
||||
@@ -2261,10 +2262,10 @@ static struct net_device_stats *airo_get_stats(struct net_device *dev)
|
||||
set_bit(JOB_STATS, &local->jobs);
|
||||
wake_up_interruptible(&local->thr_wait);
|
||||
} else
|
||||
airo_read_stats(local);
|
||||
airo_read_stats(dev);
|
||||
}
|
||||
|
||||
return &local->stats;
|
||||
return &dev->stats;
|
||||
}
|
||||
|
||||
static void airo_set_promisc(struct airo_info *ai) {
|
||||
@@ -3092,7 +3093,7 @@ static int airo_thread(void *data) {
|
||||
else if (test_bit(JOB_XMIT11, &ai->jobs))
|
||||
airo_end_xmit11(dev);
|
||||
else if (test_bit(JOB_STATS, &ai->jobs))
|
||||
airo_read_stats(ai);
|
||||
airo_read_stats(dev);
|
||||
else if (test_bit(JOB_WSTATS, &ai->jobs))
|
||||
airo_read_wireless_stats(ai);
|
||||
else if (test_bit(JOB_PROMISC, &ai->jobs))
|
||||
@@ -3288,7 +3289,7 @@ static irqreturn_t airo_interrupt(int irq, void *dev_id)
|
||||
|
||||
skb = dev_alloc_skb( len + hdrlen + 2 + 2 );
|
||||
if ( !skb ) {
|
||||
apriv->stats.rx_dropped++;
|
||||
dev->stats.rx_dropped++;
|
||||
goto badrx;
|
||||
}
|
||||
skb_reserve(skb, 2); /* This way the IP header is aligned */
|
||||
@@ -3556,7 +3557,7 @@ static void mpi_receive_802_3(struct airo_info *ai)
|
||||
|
||||
skb = dev_alloc_skb(len);
|
||||
if (!skb) {
|
||||
ai->stats.rx_dropped++;
|
||||
ai->dev->stats.rx_dropped++;
|
||||
goto badrx;
|
||||
}
|
||||
buffer = skb_put(skb,len);
|
||||
@@ -3649,7 +3650,7 @@ void mpi_receive_802_11 (struct airo_info *ai)
|
||||
|
||||
skb = dev_alloc_skb( len + hdrlen + 2 );
|
||||
if ( !skb ) {
|
||||
ai->stats.rx_dropped++;
|
||||
ai->dev->stats.rx_dropped++;
|
||||
goto badrx;
|
||||
}
|
||||
buffer = (u16*)skb_put (skb, len + hdrlen);
|
||||
|
||||
@@ -125,7 +125,7 @@ static inline int arlan_drop_tx(struct net_device *dev)
|
||||
{
|
||||
struct arlan_private *priv = netdev_priv(dev);
|
||||
|
||||
priv->stats.tx_errors++;
|
||||
dev->stats.tx_errors++;
|
||||
if (priv->Conf->tx_delay_ms)
|
||||
{
|
||||
priv->tx_done_delayed = jiffies + priv->Conf->tx_delay_ms * HZ / 1000 + 1;
|
||||
@@ -1269,7 +1269,7 @@ static void arlan_tx_done_interrupt(struct net_device *dev, int status)
|
||||
{
|
||||
IFDEBUG(ARLAN_DEBUG_TX_CHAIN)
|
||||
printk("arlan intr: transmit OK\n");
|
||||
priv->stats.tx_packets++;
|
||||
dev->stats.tx_packets++;
|
||||
priv->bad = 0;
|
||||
priv->reset = 0;
|
||||
priv->retransmissions = 0;
|
||||
@@ -1496,7 +1496,7 @@ static void arlan_rx_interrupt(struct net_device *dev, u_char rxStatus, u_short
|
||||
if (skb == NULL)
|
||||
{
|
||||
printk(KERN_ERR "%s: Memory squeeze, dropping packet.\n", dev->name);
|
||||
priv->stats.rx_dropped++;
|
||||
dev->stats.rx_dropped++;
|
||||
break;
|
||||
}
|
||||
skb_reserve(skb, 2);
|
||||
@@ -1536,14 +1536,14 @@ static void arlan_rx_interrupt(struct net_device *dev, u_char rxStatus, u_short
|
||||
}
|
||||
netif_rx(skb);
|
||||
dev->last_rx = jiffies;
|
||||
priv->stats.rx_packets++;
|
||||
priv->stats.rx_bytes += pkt_len;
|
||||
dev->stats.rx_packets++;
|
||||
dev->stats.rx_bytes += pkt_len;
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
printk(KERN_ERR "arlan intr: received unknown status\n");
|
||||
priv->stats.rx_crc_errors++;
|
||||
dev->stats.rx_crc_errors++;
|
||||
break;
|
||||
}
|
||||
ARLAN_DEBUG_EXIT("arlan_rx_interrupt");
|
||||
@@ -1719,23 +1719,23 @@ static struct net_device_stats *arlan_statistics(struct net_device *dev)
|
||||
|
||||
/* Update the statistics from the device registers. */
|
||||
|
||||
READSHM(priv->stats.collisions, arlan->numReTransmissions, u_int);
|
||||
READSHM(priv->stats.rx_crc_errors, arlan->numCRCErrors, u_int);
|
||||
READSHM(priv->stats.rx_dropped, arlan->numFramesDiscarded, u_int);
|
||||
READSHM(priv->stats.rx_fifo_errors, arlan->numRXBufferOverflows, u_int);
|
||||
READSHM(priv->stats.rx_frame_errors, arlan->numReceiveFramesLost, u_int);
|
||||
READSHM(priv->stats.rx_over_errors, arlan->numRXOverruns, u_int);
|
||||
READSHM(priv->stats.rx_packets, arlan->numDatagramsReceived, u_int);
|
||||
READSHM(priv->stats.tx_aborted_errors, arlan->numAbortErrors, u_int);
|
||||
READSHM(priv->stats.tx_carrier_errors, arlan->numStatusTimeouts, u_int);
|
||||
READSHM(priv->stats.tx_dropped, arlan->numDatagramsDiscarded, u_int);
|
||||
READSHM(priv->stats.tx_fifo_errors, arlan->numTXUnderruns, u_int);
|
||||
READSHM(priv->stats.tx_packets, arlan->numDatagramsTransmitted, u_int);
|
||||
READSHM(priv->stats.tx_window_errors, arlan->numHoldOffs, u_int);
|
||||
READSHM(dev->stats.collisions, arlan->numReTransmissions, u_int);
|
||||
READSHM(dev->stats.rx_crc_errors, arlan->numCRCErrors, u_int);
|
||||
READSHM(dev->stats.rx_dropped, arlan->numFramesDiscarded, u_int);
|
||||
READSHM(dev->stats.rx_fifo_errors, arlan->numRXBufferOverflows, u_int);
|
||||
READSHM(dev->stats.rx_frame_errors, arlan->numReceiveFramesLost, u_int);
|
||||
READSHM(dev->stats.rx_over_errors, arlan->numRXOverruns, u_int);
|
||||
READSHM(dev->stats.rx_packets, arlan->numDatagramsReceived, u_int);
|
||||
READSHM(dev->stats.tx_aborted_errors, arlan->numAbortErrors, u_int);
|
||||
READSHM(dev->stats.tx_carrier_errors, arlan->numStatusTimeouts, u_int);
|
||||
READSHM(dev->stats.tx_dropped, arlan->numDatagramsDiscarded, u_int);
|
||||
READSHM(dev->stats.tx_fifo_errors, arlan->numTXUnderruns, u_int);
|
||||
READSHM(dev->stats.tx_packets, arlan->numDatagramsTransmitted, u_int);
|
||||
READSHM(dev->stats.tx_window_errors, arlan->numHoldOffs, u_int);
|
||||
|
||||
ARLAN_DEBUG_EXIT("arlan_statistics");
|
||||
|
||||
return &priv->stats;
|
||||
return &dev->stats;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -330,7 +330,6 @@ struct TxParam
|
||||
#define TX_RING_SIZE 2
|
||||
/* Information that need to be kept for each board. */
|
||||
struct arlan_private {
|
||||
struct net_device_stats stats;
|
||||
struct arlan_shmem __iomem * card;
|
||||
struct arlan_shmem * conf;
|
||||
|
||||
|
||||
@@ -458,13 +458,11 @@ ath5k_pci_probe(struct pci_dev *pdev,
|
||||
|
||||
/* Initialize driver private data */
|
||||
SET_IEEE80211_DEV(hw, &pdev->dev);
|
||||
hw->flags = IEEE80211_HW_RX_INCLUDES_FCS;
|
||||
hw->flags = IEEE80211_HW_RX_INCLUDES_FCS |
|
||||
IEEE80211_HW_SIGNAL_DBM |
|
||||
IEEE80211_HW_NOISE_DBM;
|
||||
hw->extra_tx_headroom = 2;
|
||||
hw->channel_change_time = 5000;
|
||||
/* these names are misleading */
|
||||
hw->max_rssi = -110; /* signal in dBm */
|
||||
hw->max_noise = -110; /* noise in dBm */
|
||||
hw->max_signal = 100; /* we will provide a percentage based on rssi */
|
||||
sc = hw->priv;
|
||||
sc->hw = hw;
|
||||
sc->pdev = pdev;
|
||||
@@ -1787,6 +1785,8 @@ ath5k_tasklet_rx(unsigned long data)
|
||||
|
||||
spin_lock(&sc->rxbuflock);
|
||||
do {
|
||||
rxs.flag = 0;
|
||||
|
||||
if (unlikely(list_empty(&sc->rxbuf))) {
|
||||
ATH5K_WARN(sc, "empty rx buf pool\n");
|
||||
break;
|
||||
@@ -1893,20 +1893,9 @@ accept:
|
||||
rxs.freq = sc->curchan->center_freq;
|
||||
rxs.band = sc->curband->band;
|
||||
|
||||
/*
|
||||
* signal quality:
|
||||
* the names here are misleading and the usage of these
|
||||
* values by iwconfig makes it even worse
|
||||
*/
|
||||
/* noise floor in dBm, from the last noise calibration */
|
||||
rxs.noise = sc->ah->ah_noise_floor;
|
||||
/* signal level in dBm */
|
||||
rxs.ssi = rxs.noise + rs.rs_rssi;
|
||||
/*
|
||||
* "signal" is actually displayed as Link Quality by iwconfig
|
||||
* we provide a percentage based on rssi (assuming max rssi 64)
|
||||
*/
|
||||
rxs.signal = rs.rs_rssi * 100 / 64;
|
||||
rxs.signal = rxs.noise + rs.rs_rssi;
|
||||
rxs.qual = rs.rs_rssi * 100 / 64;
|
||||
|
||||
rxs.antenna = rs.rs_antenna;
|
||||
rxs.rate_idx = ath5k_hw_to_driver_rix(sc, rs.rs_rate);
|
||||
|
||||
@@ -4119,6 +4119,7 @@ static int ath5k_hw_proc_5210_rx_status(struct ath5k_hw *ah,
|
||||
rs->rs_tstamp = AR5K_REG_MS(rx_status->rx_status_1,
|
||||
AR5K_5210_RX_DESC_STATUS1_RECEIVE_TIMESTAMP);
|
||||
rs->rs_status = 0;
|
||||
rs->rs_phyerr = 0;
|
||||
|
||||
/*
|
||||
* Key table status
|
||||
@@ -4145,7 +4146,7 @@ static int ath5k_hw_proc_5210_rx_status(struct ath5k_hw *ah,
|
||||
if (rx_status->rx_status_1 &
|
||||
AR5K_5210_RX_DESC_STATUS1_PHY_ERROR) {
|
||||
rs->rs_status |= AR5K_RXERR_PHY;
|
||||
rs->rs_phyerr = AR5K_REG_MS(rx_status->rx_status_1,
|
||||
rs->rs_phyerr |= AR5K_REG_MS(rx_status->rx_status_1,
|
||||
AR5K_5210_RX_DESC_STATUS1_PHY_ERROR);
|
||||
}
|
||||
|
||||
@@ -4193,6 +4194,7 @@ static int ath5k_hw_proc_5212_rx_status(struct ath5k_hw *ah,
|
||||
rs->rs_tstamp = AR5K_REG_MS(rx_status->rx_status_1,
|
||||
AR5K_5212_RX_DESC_STATUS1_RECEIVE_TIMESTAMP);
|
||||
rs->rs_status = 0;
|
||||
rs->rs_phyerr = 0;
|
||||
|
||||
/*
|
||||
* Key table status
|
||||
@@ -4215,7 +4217,7 @@ static int ath5k_hw_proc_5212_rx_status(struct ath5k_hw *ah,
|
||||
if (rx_status->rx_status_1 &
|
||||
AR5K_5212_RX_DESC_STATUS1_PHY_ERROR) {
|
||||
rs->rs_status |= AR5K_RXERR_PHY;
|
||||
rs->rs_phyerr = AR5K_REG_MS(rx_err->rx_error_1,
|
||||
rs->rs_phyerr |= AR5K_REG_MS(rx_err->rx_error_1,
|
||||
AR5K_RX_DESC_ERROR1_PHY_ERROR_CODE);
|
||||
}
|
||||
|
||||
|
||||
@@ -433,7 +433,6 @@ struct atmel_private {
|
||||
struct net_device *dev;
|
||||
struct device *sys_dev;
|
||||
struct iw_statistics wstats;
|
||||
struct net_device_stats stats; // device stats
|
||||
spinlock_t irqlock, timerlock; // spinlocks
|
||||
enum { BUS_TYPE_PCCARD, BUS_TYPE_PCI } bus_type;
|
||||
enum {
|
||||
@@ -694,9 +693,9 @@ static void tx_done_irq(struct atmel_private *priv)
|
||||
|
||||
if (type == TX_PACKET_TYPE_DATA) {
|
||||
if (status == TX_STATUS_SUCCESS)
|
||||
priv->stats.tx_packets++;
|
||||
priv->dev->stats.tx_packets++;
|
||||
else
|
||||
priv->stats.tx_errors++;
|
||||
priv->dev->stats.tx_errors++;
|
||||
netif_wake_queue(priv->dev);
|
||||
}
|
||||
}
|
||||
@@ -792,13 +791,13 @@ static int start_tx(struct sk_buff *skb, struct net_device *dev)
|
||||
|
||||
if (priv->card && priv->present_callback &&
|
||||
!(*priv->present_callback)(priv->card)) {
|
||||
priv->stats.tx_errors++;
|
||||
dev->stats.tx_errors++;
|
||||
dev_kfree_skb(skb);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (priv->station_state != STATION_STATE_READY) {
|
||||
priv->stats.tx_errors++;
|
||||
dev->stats.tx_errors++;
|
||||
dev_kfree_skb(skb);
|
||||
return 0;
|
||||
}
|
||||
@@ -815,7 +814,7 @@ static int start_tx(struct sk_buff *skb, struct net_device *dev)
|
||||
initial + 18 (+30-12) */
|
||||
|
||||
if (!(buff = find_tx_buff(priv, len + 18))) {
|
||||
priv->stats.tx_dropped++;
|
||||
dev->stats.tx_dropped++;
|
||||
spin_unlock_irqrestore(&priv->irqlock, flags);
|
||||
spin_unlock_bh(&priv->timerlock);
|
||||
netif_stop_queue(dev);
|
||||
@@ -851,7 +850,7 @@ static int start_tx(struct sk_buff *skb, struct net_device *dev)
|
||||
/* low bit of first byte of destination tells us if broadcast */
|
||||
tx_update_descriptor(priv, *(skb->data) & 0x01, len + 18, buff, TX_PACKET_TYPE_DATA);
|
||||
dev->trans_start = jiffies;
|
||||
priv->stats.tx_bytes += len;
|
||||
dev->stats.tx_bytes += len;
|
||||
|
||||
spin_unlock_irqrestore(&priv->irqlock, flags);
|
||||
spin_unlock_bh(&priv->timerlock);
|
||||
@@ -895,7 +894,7 @@ static void fast_rx_path(struct atmel_private *priv,
|
||||
}
|
||||
|
||||
if (!(skb = dev_alloc_skb(msdu_size + 14))) {
|
||||
priv->stats.rx_dropped++;
|
||||
priv->dev->stats.rx_dropped++;
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -908,7 +907,7 @@ static void fast_rx_path(struct atmel_private *priv,
|
||||
crc = crc32_le(crc, skbp + 12, msdu_size);
|
||||
atmel_copy_to_host(priv->dev, (void *)&netcrc, rx_packet_loc + 30 + msdu_size, 4);
|
||||
if ((crc ^ 0xffffffff) != netcrc) {
|
||||
priv->stats.rx_crc_errors++;
|
||||
priv->dev->stats.rx_crc_errors++;
|
||||
dev_kfree_skb(skb);
|
||||
return;
|
||||
}
|
||||
@@ -924,8 +923,8 @@ static void fast_rx_path(struct atmel_private *priv,
|
||||
skb->protocol = eth_type_trans(skb, priv->dev);
|
||||
skb->ip_summed = CHECKSUM_NONE;
|
||||
netif_rx(skb);
|
||||
priv->stats.rx_bytes += 12 + msdu_size;
|
||||
priv->stats.rx_packets++;
|
||||
priv->dev->stats.rx_bytes += 12 + msdu_size;
|
||||
priv->dev->stats.rx_packets++;
|
||||
}
|
||||
|
||||
/* Test to see if the packet in card memory at packet_loc has a valid CRC
|
||||
@@ -991,7 +990,7 @@ static void frag_rx_path(struct atmel_private *priv,
|
||||
crc = crc32_le(crc, &priv->rx_buf[12], msdu_size);
|
||||
atmel_copy_to_host(priv->dev, (void *)&netcrc, rx_packet_loc + msdu_size, 4);
|
||||
if ((crc ^ 0xffffffff) != netcrc) {
|
||||
priv->stats.rx_crc_errors++;
|
||||
priv->dev->stats.rx_crc_errors++;
|
||||
memset(priv->frag_source, 0xff, 6);
|
||||
}
|
||||
}
|
||||
@@ -1009,7 +1008,7 @@ static void frag_rx_path(struct atmel_private *priv,
|
||||
msdu_size);
|
||||
atmel_copy_to_host(priv->dev, (void *)&netcrc, rx_packet_loc + msdu_size, 4);
|
||||
if ((crc ^ 0xffffffff) != netcrc) {
|
||||
priv->stats.rx_crc_errors++;
|
||||
priv->dev->stats.rx_crc_errors++;
|
||||
memset(priv->frag_source, 0xff, 6);
|
||||
more_frags = 1; /* don't send broken assembly */
|
||||
}
|
||||
@@ -1021,7 +1020,7 @@ static void frag_rx_path(struct atmel_private *priv,
|
||||
if (!more_frags) { /* last one */
|
||||
memset(priv->frag_source, 0xff, 6);
|
||||
if (!(skb = dev_alloc_skb(priv->frag_len + 14))) {
|
||||
priv->stats.rx_dropped++;
|
||||
priv->dev->stats.rx_dropped++;
|
||||
} else {
|
||||
skb_reserve(skb, 2);
|
||||
memcpy(skb_put(skb, priv->frag_len + 12),
|
||||
@@ -1031,8 +1030,8 @@ static void frag_rx_path(struct atmel_private *priv,
|
||||
skb->protocol = eth_type_trans(skb, priv->dev);
|
||||
skb->ip_summed = CHECKSUM_NONE;
|
||||
netif_rx(skb);
|
||||
priv->stats.rx_bytes += priv->frag_len + 12;
|
||||
priv->stats.rx_packets++;
|
||||
priv->dev->stats.rx_bytes += priv->frag_len + 12;
|
||||
priv->dev->stats.rx_packets++;
|
||||
}
|
||||
}
|
||||
} else
|
||||
@@ -1057,7 +1056,7 @@ static void rx_done_irq(struct atmel_private *priv)
|
||||
if (status == 0xc1) /* determined by experiment */
|
||||
priv->wstats.discard.nwid++;
|
||||
else
|
||||
priv->stats.rx_errors++;
|
||||
priv->dev->stats.rx_errors++;
|
||||
goto next;
|
||||
}
|
||||
|
||||
@@ -1065,7 +1064,7 @@ static void rx_done_irq(struct atmel_private *priv)
|
||||
rx_packet_loc = atmel_rmem16(priv, atmel_rx(priv, RX_DESC_MSDU_POS_OFFSET, priv->rx_desc_head));
|
||||
|
||||
if (msdu_size < 30) {
|
||||
priv->stats.rx_errors++;
|
||||
priv->dev->stats.rx_errors++;
|
||||
goto next;
|
||||
}
|
||||
|
||||
@@ -1123,7 +1122,7 @@ static void rx_done_irq(struct atmel_private *priv)
|
||||
msdu_size -= 4;
|
||||
crc = crc32_le(crc, (unsigned char *)&priv->rx_buf, msdu_size);
|
||||
if ((crc ^ 0xffffffff) != (*((u32 *)&priv->rx_buf[msdu_size]))) {
|
||||
priv->stats.rx_crc_errors++;
|
||||
priv->dev->stats.rx_crc_errors++;
|
||||
goto next;
|
||||
}
|
||||
}
|
||||
@@ -1250,12 +1249,6 @@ static irqreturn_t service_interrupt(int irq, void *dev_id)
|
||||
}
|
||||
}
|
||||
|
||||
static struct net_device_stats *atmel_get_stats(struct net_device *dev)
|
||||
{
|
||||
struct atmel_private *priv = netdev_priv(dev);
|
||||
return &priv->stats;
|
||||
}
|
||||
|
||||
static struct iw_statistics *atmel_get_wireless_stats(struct net_device *dev)
|
||||
{
|
||||
struct atmel_private *priv = netdev_priv(dev);
|
||||
@@ -1518,8 +1511,6 @@ struct net_device *init_atmel_card(unsigned short irq, unsigned long port,
|
||||
priv->crc_ok_cnt = priv->crc_ko_cnt = 0;
|
||||
} else
|
||||
priv->probe_crc = 0;
|
||||
memset(&priv->stats, 0, sizeof(priv->stats));
|
||||
memset(&priv->wstats, 0, sizeof(priv->wstats));
|
||||
priv->last_qual = jiffies;
|
||||
priv->last_beacon_timestamp = 0;
|
||||
memset(priv->frag_source, 0xff, sizeof(priv->frag_source));
|
||||
@@ -1568,7 +1559,6 @@ struct net_device *init_atmel_card(unsigned short irq, unsigned long port,
|
||||
dev->change_mtu = atmel_change_mtu;
|
||||
dev->set_mac_address = atmel_set_mac_address;
|
||||
dev->hard_start_xmit = start_tx;
|
||||
dev->get_stats = atmel_get_stats;
|
||||
dev->wireless_handlers = (struct iw_handler_def *)&atmel_handler_def;
|
||||
dev->do_ioctl = atmel_ioctl;
|
||||
dev->irq = irq;
|
||||
|
||||
@@ -939,22 +939,6 @@ static inline bool __b43_warn_on_dummy(bool x) { return x; }
|
||||
# define B43_WARN_ON(x) __b43_warn_on_dummy(unlikely(!!(x)))
|
||||
#endif
|
||||
|
||||
/** Limit a value between two limits */
|
||||
#ifdef limit_value
|
||||
# undef limit_value
|
||||
#endif
|
||||
#define limit_value(value, min, max) \
|
||||
({ \
|
||||
typeof(value) __value = (value); \
|
||||
typeof(value) __min = (min); \
|
||||
typeof(value) __max = (max); \
|
||||
if (__value < __min) \
|
||||
__value = __min; \
|
||||
else if (__value > __max) \
|
||||
__value = __max; \
|
||||
__value; \
|
||||
})
|
||||
|
||||
/* Convert an integer to a Q5.2 value */
|
||||
#define INT_TO_Q52(i) ((i) << 2)
|
||||
/* Convert a Q5.2 value to an integer (precision loss!) */
|
||||
|
||||
@@ -199,7 +199,7 @@ static void lo_measure_txctl_values(struct b43_wldev *dev)
|
||||
if (lb_gain > 10) {
|
||||
radio_pctl_reg = 0;
|
||||
pga = abs(10 - lb_gain) / 6;
|
||||
pga = limit_value(pga, 0, 15);
|
||||
pga = clamp_val(pga, 0, 15);
|
||||
} else {
|
||||
int cmp_val;
|
||||
int tmp;
|
||||
@@ -321,7 +321,7 @@ static void lo_measure_gain_values(struct b43_wldev *dev,
|
||||
phy->lna_lod_gain = 1;
|
||||
trsw_rx_gain -= 8;
|
||||
}
|
||||
trsw_rx_gain = limit_value(trsw_rx_gain, 0, 0x2D);
|
||||
trsw_rx_gain = clamp_val(trsw_rx_gain, 0, 0x2D);
|
||||
phy->pga_gain = trsw_rx_gain / 3;
|
||||
if (phy->pga_gain >= 5) {
|
||||
phy->pga_gain -= 5;
|
||||
|
||||
@@ -1182,10 +1182,10 @@ static void handle_irq_noise(struct b43_wldev *dev)
|
||||
/* Get the noise samples. */
|
||||
B43_WARN_ON(dev->noisecalc.nr_samples >= 8);
|
||||
i = dev->noisecalc.nr_samples;
|
||||
noise[0] = limit_value(noise[0], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[1] = limit_value(noise[1], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[2] = limit_value(noise[2], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[3] = limit_value(noise[3], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[0] = clamp_val(noise[0], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[1] = clamp_val(noise[1], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[2] = clamp_val(noise[2], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[3] = clamp_val(noise[3], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
dev->noisecalc.samples[i][0] = phy->nrssi_lt[noise[0]];
|
||||
dev->noisecalc.samples[i][1] = phy->nrssi_lt[noise[1]];
|
||||
dev->noisecalc.samples[i][2] = phy->nrssi_lt[noise[2]];
|
||||
@@ -4466,10 +4466,10 @@ static int b43_wireless_init(struct ssb_device *dev)
|
||||
|
||||
/* fill hw info */
|
||||
hw->flags = IEEE80211_HW_HOST_GEN_BEACON_TEMPLATE |
|
||||
IEEE80211_HW_RX_INCLUDES_FCS;
|
||||
hw->max_signal = 100;
|
||||
hw->max_rssi = -110;
|
||||
hw->max_noise = -110;
|
||||
IEEE80211_HW_RX_INCLUDES_FCS |
|
||||
IEEE80211_HW_SIGNAL_DBM |
|
||||
IEEE80211_HW_NOISE_DBM;
|
||||
|
||||
hw->queues = b43_modparam_qos ? 4 : 1;
|
||||
SET_IEEE80211_DEV(hw, dev->dev);
|
||||
if (is_valid_ether_addr(sprom->et1mac))
|
||||
|
||||
@@ -29,8 +29,6 @@
|
||||
#include "nphy.h"
|
||||
#include "tables_nphy.h"
|
||||
|
||||
#include <linux/delay.h>
|
||||
|
||||
|
||||
void b43_nphy_set_rxantenna(struct b43_wldev *dev, int antenna)
|
||||
{//TODO
|
||||
|
||||
@@ -28,6 +28,7 @@
|
||||
#include <linux/delay.h>
|
||||
#include <linux/io.h>
|
||||
#include <linux/types.h>
|
||||
#include <linux/bitrev.h>
|
||||
|
||||
#include "b43.h"
|
||||
#include "phy.h"
|
||||
@@ -83,25 +84,9 @@ const u8 b43_radio_channel_codes_bg[] = {
|
||||
72, 84,
|
||||
};
|
||||
|
||||
#define bitrev4(tmp) (bitrev8(tmp) >> 4)
|
||||
static void b43_phy_initg(struct b43_wldev *dev);
|
||||
|
||||
/* Reverse the bits of a 4bit value.
|
||||
* Example: 1101 is flipped 1011
|
||||
*/
|
||||
static u16 flip_4bit(u16 value)
|
||||
{
|
||||
u16 flipped = 0x0000;
|
||||
|
||||
B43_WARN_ON(value & ~0x000F);
|
||||
|
||||
flipped |= (value & 0x0001) << 3;
|
||||
flipped |= (value & 0x0002) << 1;
|
||||
flipped |= (value & 0x0004) >> 1;
|
||||
flipped |= (value & 0x0008) >> 3;
|
||||
|
||||
return flipped;
|
||||
}
|
||||
|
||||
static void generate_rfatt_list(struct b43_wldev *dev,
|
||||
struct b43_rfatt_list *list)
|
||||
{
|
||||
@@ -1415,7 +1400,7 @@ static void b43_phy_initg(struct b43_wldev *dev)
|
||||
* the value 0x7FFFFFFF here. I think that is some weird
|
||||
* compiler optimization in the original driver.
|
||||
* Essentially, what we do here is resetting all NRSSI LT
|
||||
* entries to -32 (see the limit_value() in nrssi_hw_update())
|
||||
* entries to -32 (see the clamp_val() in nrssi_hw_update())
|
||||
*/
|
||||
b43_nrssi_hw_update(dev, 0xFFFF); //FIXME?
|
||||
b43_calc_nrssi_threshold(dev);
|
||||
@@ -1477,13 +1462,13 @@ static s8 b43_phy_estimate_power_out(struct b43_wldev *dev, s8 tssi)
|
||||
switch (phy->type) {
|
||||
case B43_PHYTYPE_A:
|
||||
tmp += 0x80;
|
||||
tmp = limit_value(tmp, 0x00, 0xFF);
|
||||
tmp = clamp_val(tmp, 0x00, 0xFF);
|
||||
dbm = phy->tssi2dbm[tmp];
|
||||
//TODO: There's a FIXME on the specs
|
||||
break;
|
||||
case B43_PHYTYPE_B:
|
||||
case B43_PHYTYPE_G:
|
||||
tmp = limit_value(tmp, 0x00, 0x3F);
|
||||
tmp = clamp_val(tmp, 0x00, 0x3F);
|
||||
dbm = phy->tssi2dbm[tmp];
|
||||
break;
|
||||
default:
|
||||
@@ -1542,8 +1527,8 @@ void b43_put_attenuation_into_ranges(struct b43_wldev *dev,
|
||||
break;
|
||||
}
|
||||
|
||||
*_rfatt = limit_value(rfatt, rf_min, rf_max);
|
||||
*_bbatt = limit_value(bbatt, bb_min, bb_max);
|
||||
*_rfatt = clamp_val(rfatt, rf_min, rf_max);
|
||||
*_bbatt = clamp_val(bbatt, bb_min, bb_max);
|
||||
}
|
||||
|
||||
/* http://bcm-specs.sipsolutions.net/RecalculateTransmissionPower */
|
||||
@@ -1638,7 +1623,7 @@ void b43_phy_xmitpower(struct b43_wldev *dev)
|
||||
/* Get desired power (in Q5.2) */
|
||||
desired_pwr = INT_TO_Q52(phy->power_level);
|
||||
/* And limit it. max_pwr already is Q5.2 */
|
||||
desired_pwr = limit_value(desired_pwr, 0, max_pwr);
|
||||
desired_pwr = clamp_val(desired_pwr, 0, max_pwr);
|
||||
if (b43_debug(dev, B43_DBG_XMITPOWER)) {
|
||||
b43dbg(dev->wl,
|
||||
"Current TX power output: " Q52_FMT
|
||||
@@ -1748,7 +1733,7 @@ static inline
|
||||
f = q;
|
||||
i++;
|
||||
} while (delta >= 2);
|
||||
entry[index] = limit_value(b43_tssi2dbm_ad(m1 * f, 8192), -127, 128);
|
||||
entry[index] = clamp_val(b43_tssi2dbm_ad(m1 * f, 8192), -127, 128);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -2274,7 +2259,7 @@ void b43_nrssi_hw_update(struct b43_wldev *dev, u16 val)
|
||||
for (i = 0; i < 64; i++) {
|
||||
tmp = b43_nrssi_hw_read(dev, i);
|
||||
tmp -= val;
|
||||
tmp = limit_value(tmp, -32, 31);
|
||||
tmp = clamp_val(tmp, -32, 31);
|
||||
b43_nrssi_hw_write(dev, i, tmp);
|
||||
}
|
||||
}
|
||||
@@ -2291,7 +2276,7 @@ void b43_nrssi_mem_update(struct b43_wldev *dev)
|
||||
tmp = (i - delta) * phy->nrssislope;
|
||||
tmp /= 0x10000;
|
||||
tmp += 0x3A;
|
||||
tmp = limit_value(tmp, 0, 0x3F);
|
||||
tmp = clamp_val(tmp, 0, 0x3F);
|
||||
phy->nrssi_lt[i] = tmp;
|
||||
}
|
||||
}
|
||||
@@ -2728,7 +2713,7 @@ void b43_calc_nrssi_threshold(struct b43_wldev *dev)
|
||||
} else
|
||||
threshold = phy->nrssi[1] - 5;
|
||||
|
||||
threshold = limit_value(threshold, 0, 0x3E);
|
||||
threshold = clamp_val(threshold, 0, 0x3E);
|
||||
b43_phy_read(dev, 0x0020); /* dummy read */
|
||||
b43_phy_write(dev, 0x0020,
|
||||
(((u16) threshold) << 8) | 0x001C);
|
||||
@@ -2779,7 +2764,7 @@ void b43_calc_nrssi_threshold(struct b43_wldev *dev)
|
||||
else
|
||||
a += 32;
|
||||
a = a >> 6;
|
||||
a = limit_value(a, -31, 31);
|
||||
a = clamp_val(a, -31, 31);
|
||||
|
||||
b = b * (phy->nrssi[1] - phy->nrssi[0]);
|
||||
b += (phy->nrssi[0] << 6);
|
||||
@@ -2788,7 +2773,7 @@ void b43_calc_nrssi_threshold(struct b43_wldev *dev)
|
||||
else
|
||||
b += 32;
|
||||
b = b >> 6;
|
||||
b = limit_value(b, -31, 31);
|
||||
b = clamp_val(b, -31, 31);
|
||||
|
||||
tmp_u16 = b43_phy_read(dev, 0x048A) & 0xF000;
|
||||
tmp_u16 |= ((u32) b & 0x0000003F);
|
||||
@@ -2891,13 +2876,13 @@ b43_radio_interference_mitigation_enable(struct b43_wldev *dev, int mode)
|
||||
}
|
||||
radio_stacksave(0x0078);
|
||||
tmp = (b43_radio_read16(dev, 0x0078) & 0x001E);
|
||||
flipped = flip_4bit(tmp);
|
||||
B43_WARN_ON(tmp > 15);
|
||||
flipped = bitrev4(tmp);
|
||||
if (flipped < 10 && flipped >= 8)
|
||||
flipped = 7;
|
||||
else if (flipped >= 10)
|
||||
flipped -= 3;
|
||||
flipped = flip_4bit(flipped);
|
||||
flipped = (flipped << 1) | 0x0020;
|
||||
flipped = (bitrev4(flipped) << 1) | 0x0020;
|
||||
b43_radio_write16(dev, 0x0078, flipped);
|
||||
|
||||
b43_calc_nrssi_threshold(dev);
|
||||
@@ -3530,7 +3515,7 @@ u16 b43_radio_init2050(struct b43_wldev *dev)
|
||||
tmp1 >>= 9;
|
||||
|
||||
for (i = 0; i < 16; i++) {
|
||||
radio78 = ((flip_4bit(i) << 1) | 0x20);
|
||||
radio78 = (bitrev4(i) << 1) | 0x0020;
|
||||
b43_radio_write16(dev, 0x78, radio78);
|
||||
udelay(10);
|
||||
for (j = 0; j < 16; j++) {
|
||||
|
||||
@@ -581,12 +581,11 @@ void b43_rx(struct b43_wldev *dev, struct sk_buff *skb, const void *_rxhdr)
|
||||
// and also find out what the maximum possible value is.
|
||||
// Fill status.ssi and status.signal fields.
|
||||
} else {
|
||||
status.ssi = b43_rssi_postprocess(dev, rxhdr->jssi,
|
||||
status.signal = b43_rssi_postprocess(dev, rxhdr->jssi,
|
||||
(phystat0 & B43_RX_PHYST0_OFDM),
|
||||
(phystat0 & B43_RX_PHYST0_GAINCTL),
|
||||
(phystat3 & B43_RX_PHYST3_TRSTATE));
|
||||
/* the next line looks wrong, but is what mac80211 wants */
|
||||
status.signal = (rxhdr->jssi * 100) / B43_RX_MAX_SSI;
|
||||
status.qual = (rxhdr->jssi * 100) / B43_RX_MAX_SSI;
|
||||
}
|
||||
|
||||
if (phystat0 & B43_RX_PHYST0_OFDM)
|
||||
|
||||
@@ -823,23 +823,6 @@ void b43legacydbg(struct b43legacy_wl *wl, const char *fmt, ...)
|
||||
# define b43legacydbg(wl, fmt...) do { /* nothing */ } while (0)
|
||||
#endif /* DEBUG */
|
||||
|
||||
|
||||
/** Limit a value between two limits */
|
||||
#ifdef limit_value
|
||||
# undef limit_value
|
||||
#endif
|
||||
#define limit_value(value, min, max) \
|
||||
({ \
|
||||
typeof(value) __value = (value); \
|
||||
typeof(value) __min = (min); \
|
||||
typeof(value) __max = (max); \
|
||||
if (__value < __min) \
|
||||
__value = __min; \
|
||||
else if (__value > __max) \
|
||||
__value = __max; \
|
||||
__value; \
|
||||
})
|
||||
|
||||
/* Macros for printing a value in Q5.2 format */
|
||||
#define Q52_FMT "%u.%u"
|
||||
#define Q52_ARG(q52) ((q52) / 4), (((q52) & 3) * 100 / 4)
|
||||
|
||||
@@ -846,10 +846,10 @@ static void handle_irq_noise(struct b43legacy_wldev *dev)
|
||||
/* Get the noise samples. */
|
||||
B43legacy_WARN_ON(dev->noisecalc.nr_samples >= 8);
|
||||
i = dev->noisecalc.nr_samples;
|
||||
noise[0] = limit_value(noise[0], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[1] = limit_value(noise[1], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[2] = limit_value(noise[2], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[3] = limit_value(noise[3], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[0] = clamp_val(noise[0], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[1] = clamp_val(noise[1], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[2] = clamp_val(noise[2], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
noise[3] = clamp_val(noise[3], 0, ARRAY_SIZE(phy->nrssi_lt) - 1);
|
||||
dev->noisecalc.samples[i][0] = phy->nrssi_lt[noise[0]];
|
||||
dev->noisecalc.samples[i][1] = phy->nrssi_lt[noise[1]];
|
||||
dev->noisecalc.samples[i][2] = phy->nrssi_lt[noise[2]];
|
||||
@@ -3718,10 +3718,9 @@ static int b43legacy_wireless_init(struct ssb_device *dev)
|
||||
|
||||
/* fill hw info */
|
||||
hw->flags = IEEE80211_HW_HOST_GEN_BEACON_TEMPLATE |
|
||||
IEEE80211_HW_RX_INCLUDES_FCS;
|
||||
hw->max_signal = 100;
|
||||
hw->max_rssi = -110;
|
||||
hw->max_noise = -110;
|
||||
IEEE80211_HW_RX_INCLUDES_FCS |
|
||||
IEEE80211_HW_SIGNAL_DBM |
|
||||
IEEE80211_HW_NOISE_DBM;
|
||||
hw->queues = 1; /* FIXME: hardware has more queues */
|
||||
SET_IEEE80211_DEV(hw, dev->dev);
|
||||
if (is_valid_ether_addr(sprom->et1mac))
|
||||
|
||||
@@ -1088,7 +1088,7 @@ static void b43legacy_phy_initg(struct b43legacy_wldev *dev)
|
||||
* the value 0x7FFFFFFF here. I think that is some weird
|
||||
* compiler optimization in the original driver.
|
||||
* Essentially, what we do here is resetting all NRSSI LT
|
||||
* entries to -32 (see the limit_value() in nrssi_hw_update())
|
||||
* entries to -32 (see the clamp_val() in nrssi_hw_update())
|
||||
*/
|
||||
b43legacy_nrssi_hw_update(dev, 0xFFFF);
|
||||
b43legacy_calc_nrssi_threshold(dev);
|
||||
@@ -1756,7 +1756,7 @@ static s8 b43legacy_phy_estimate_power_out(struct b43legacy_wldev *dev, s8 tssi)
|
||||
switch (phy->type) {
|
||||
case B43legacy_PHYTYPE_B:
|
||||
case B43legacy_PHYTYPE_G:
|
||||
tmp = limit_value(tmp, 0x00, 0x3F);
|
||||
tmp = clamp_val(tmp, 0x00, 0x3F);
|
||||
dbm = phy->tssi2dbm[tmp];
|
||||
break;
|
||||
default:
|
||||
@@ -1859,7 +1859,7 @@ void b43legacy_phy_xmitpower(struct b43legacy_wldev *dev)
|
||||
|
||||
/* find the desired power in Q5.2 - power_level is in dBm
|
||||
* and limit it - max_pwr is already in Q5.2 */
|
||||
desired_pwr = limit_value(phy->power_level << 2, 0, max_pwr);
|
||||
desired_pwr = clamp_val(phy->power_level << 2, 0, max_pwr);
|
||||
if (b43legacy_debug(dev, B43legacy_DBG_XMITPOWER))
|
||||
b43legacydbg(dev->wl, "Current TX power output: " Q52_FMT
|
||||
" dBm, Desired TX power output: " Q52_FMT
|
||||
@@ -1905,7 +1905,7 @@ void b43legacy_phy_xmitpower(struct b43legacy_wldev *dev)
|
||||
radio_attenuation++;
|
||||
}
|
||||
}
|
||||
baseband_attenuation = limit_value(baseband_attenuation, 0, 11);
|
||||
baseband_attenuation = clamp_val(baseband_attenuation, 0, 11);
|
||||
|
||||
txpower = phy->txctl1;
|
||||
if ((phy->radio_ver == 0x2050) && (phy->radio_rev == 2)) {
|
||||
@@ -1933,8 +1933,8 @@ void b43legacy_phy_xmitpower(struct b43legacy_wldev *dev)
|
||||
}
|
||||
/* Save the control values */
|
||||
phy->txctl1 = txpower;
|
||||
baseband_attenuation = limit_value(baseband_attenuation, 0, 11);
|
||||
radio_attenuation = limit_value(radio_attenuation, 0, 9);
|
||||
baseband_attenuation = clamp_val(baseband_attenuation, 0, 11);
|
||||
radio_attenuation = clamp_val(radio_attenuation, 0, 9);
|
||||
phy->rfatt = radio_attenuation;
|
||||
phy->bbatt = baseband_attenuation;
|
||||
|
||||
@@ -1979,7 +1979,7 @@ s8 b43legacy_tssi2dbm_entry(s8 entry [], u8 index, s16 pab0, s16 pab1, s16 pab2)
|
||||
f = q;
|
||||
i++;
|
||||
} while (delta >= 2);
|
||||
entry[index] = limit_value(b43legacy_tssi2dbm_ad(m1 * f, 8192),
|
||||
entry[index] = clamp_val(b43legacy_tssi2dbm_ad(m1 * f, 8192),
|
||||
-127, 128);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -357,7 +357,7 @@ void b43legacy_nrssi_hw_update(struct b43legacy_wldev *dev, u16 val)
|
||||
for (i = 0; i < 64; i++) {
|
||||
tmp = b43legacy_nrssi_hw_read(dev, i);
|
||||
tmp -= val;
|
||||
tmp = limit_value(tmp, -32, 31);
|
||||
tmp = clamp_val(tmp, -32, 31);
|
||||
b43legacy_nrssi_hw_write(dev, i, tmp);
|
||||
}
|
||||
}
|
||||
@@ -375,7 +375,7 @@ void b43legacy_nrssi_mem_update(struct b43legacy_wldev *dev)
|
||||
tmp = (i - delta) * phy->nrssislope;
|
||||
tmp /= 0x10000;
|
||||
tmp += 0x3A;
|
||||
tmp = limit_value(tmp, 0, 0x3F);
|
||||
tmp = clamp_val(tmp, 0, 0x3F);
|
||||
phy->nrssi_lt[i] = tmp;
|
||||
}
|
||||
}
|
||||
@@ -839,7 +839,7 @@ void b43legacy_calc_nrssi_threshold(struct b43legacy_wldev *dev)
|
||||
} else
|
||||
threshold = phy->nrssi[1] - 5;
|
||||
|
||||
threshold = limit_value(threshold, 0, 0x3E);
|
||||
threshold = clamp_val(threshold, 0, 0x3E);
|
||||
b43legacy_phy_read(dev, 0x0020); /* dummy read */
|
||||
b43legacy_phy_write(dev, 0x0020, (((u16)threshold) << 8)
|
||||
| 0x001C);
|
||||
@@ -892,7 +892,7 @@ void b43legacy_calc_nrssi_threshold(struct b43legacy_wldev *dev)
|
||||
else
|
||||
a += 32;
|
||||
a = a >> 6;
|
||||
a = limit_value(a, -31, 31);
|
||||
a = clamp_val(a, -31, 31);
|
||||
|
||||
b = b * (phy->nrssi[1] - phy->nrssi[0]);
|
||||
b += (phy->nrssi[0] << 6);
|
||||
@@ -901,7 +901,7 @@ void b43legacy_calc_nrssi_threshold(struct b43legacy_wldev *dev)
|
||||
else
|
||||
b += 32;
|
||||
b = b >> 6;
|
||||
b = limit_value(b, -31, 31);
|
||||
b = clamp_val(b, -31, 31);
|
||||
|
||||
tmp_u16 = b43legacy_phy_read(dev, 0x048A) & 0xF000;
|
||||
tmp_u16 |= ((u32)b & 0x0000003F);
|
||||
@@ -1905,7 +1905,7 @@ void b43legacy_radio_set_txpower_a(struct b43legacy_wldev *dev, u16 txpower)
|
||||
u16 dac;
|
||||
u16 ilt;
|
||||
|
||||
txpower = limit_value(txpower, 0, 63);
|
||||
txpower = clamp_val(txpower, 0, 63);
|
||||
|
||||
pamp = b43legacy_get_txgain_freq_power_amp(txpower);
|
||||
pamp <<= 5;
|
||||
|
||||
@@ -532,12 +532,12 @@ void b43legacy_rx(struct b43legacy_wldev *dev,
|
||||
}
|
||||
}
|
||||
|
||||
status.ssi = b43legacy_rssi_postprocess(dev, jssi,
|
||||
status.signal = b43legacy_rssi_postprocess(dev, jssi,
|
||||
(phystat0 & B43legacy_RX_PHYST0_OFDM),
|
||||
(phystat0 & B43legacy_RX_PHYST0_GAINCTL),
|
||||
(phystat3 & B43legacy_RX_PHYST3_TRSTATE));
|
||||
status.noise = dev->stats.link_noise;
|
||||
status.signal = (jssi * 100) / B43legacy_RX_MAX_SSI;
|
||||
status.qual = (jssi * 100) / B43legacy_RX_MAX_SSI;
|
||||
/* change to support A PHY */
|
||||
if (phystat0 & B43legacy_RX_PHYST0_OFDM)
|
||||
status.rate_idx = b43legacy_plcp_get_bitrate_idx_ofdm(plcp, false);
|
||||
|
||||
@@ -96,13 +96,13 @@ config IWLWIFI_DEBUG
|
||||
control which debug output is sent to the kernel log by setting the
|
||||
value in
|
||||
|
||||
/sys/bus/pci/drivers/${DRIVER}/debug_level
|
||||
/sys/class/net/wlan0/device/debug_level
|
||||
|
||||
This entry will only exist if this option is enabled.
|
||||
|
||||
To set a value, simply echo an 8-byte hex value to the same file:
|
||||
|
||||
% echo 0x43fff > /sys/bus/pci/drivers/${DRIVER}/debug_level
|
||||
% echo 0x43fff > /sys/class/net/wlan0/device/debug_level
|
||||
|
||||
You can find the list of debug mask values in:
|
||||
drivers/net/wireless/iwlwifi/iwl-4965-debug.h
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
obj-$(CONFIG_IWLCORE) += iwlcore.o
|
||||
iwlcore-objs := iwl-core.o iwl-eeprom.o iwl-hcmd.o iwl-power.o
|
||||
iwlcore-objs += iwl-rx.o iwl-tx.o iwl-sta.o
|
||||
iwlcore-$(CONFIG_IWLWIFI_DEBUGFS) += iwl-debugfs.o
|
||||
iwlcore-$(CONFIG_IWLWIFI_LEDS) += iwl-led.o
|
||||
iwlcore-$(CONFIG_IWLWIFI_RFKILL) += iwl-rfkill.o
|
||||
@@ -10,7 +11,7 @@ iwl3945-objs := iwl3945-base.o iwl-3945.o iwl-3945-rs.o
|
||||
iwl3945-$(CONFIG_IWL3945_LEDS) += iwl-3945-led.o
|
||||
|
||||
obj-$(CONFIG_IWL4965) += iwl4965.o
|
||||
iwl4965-objs := iwl4965-base.o iwl-4965.o iwl-4965-rs.o iwl-sta.o
|
||||
iwl4965-objs := iwl4965-base.o iwl-4965.o iwl-4965-rs.o
|
||||
|
||||
ifeq ($(CONFIG_IWL5000),y)
|
||||
iwl4965-objs += iwl-5000.o
|
||||
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user